【发布时间】:2018-01-21 09:02:18
【问题描述】:
文档说:
$user = User::find($user_id);
$user->delete();
这不起作用,但是 ProductColor::find($color_id) 工作。 $color->delete() 不返回任何内容,DELETE FROM 查询甚至不执行(如调试栏中所示)。
但我可以删除记录:
ProductColor::destroy($color_id);
一定是我之前忽略的东西,我是 Laravel 的新手。
我也在使用商店,它按预期工作
public function store(Request $request)
{
$color = new ProductColor();
$color->name = $request->color_name;
$color->order = $request->color_order;
$saved = $color->save();
if ($saved) {
return back()->with('message:success', 'Ok');
} else {
return back()->with('message:error', 'Error');
}
}
总结一下
这个作品
public function destroy($color_id)
{
$deleted = ProductColor::destroy($color_id);
if ($deleted) {
return back()->with('message:success', 'Deleted');
} else {
return back()->with('message:error', 'Error');
}
}
这不是
public function destroy($color_id)
{
$color = ProductColor::find($color_id);
$color->delete();
}
我的模特
<?php
namespace Modules\Shop\Entities;
use Illuminate\Database\Eloquent\Model;
use Modules\Languages\Entities\Language;
class ProductColor extends Model
{
protected $fillable = [];
protected $table = 'product_colors';
}
【问题讨论】:
-
真的我不知道为什么这不起作用。但是你为什么不试试查询呢?
$user = User::where('user_id', $user_id)->delete(); -
我的 IDE 显示 'where' 不是静态方法,所以我只使用了 User::destroy($user_id);
-
尝试使用
delete()时出现什么错误? -
正如我所说,没有错误,没有什么只是没有执行。
标签: php laravel laravel-5 eloquent laravel-eloquent