我的猜测是使用以下语法:
MyModel::all()->delete();
但这并没有起作用。我相信这是超级简单的,但我已经搜索了关于这个主题的文档,但找不到它!
我的猜测是使用以下语法:
MyModel::all()->delete();
但这并没有起作用。我相信这是超级简单的,但我已经搜索了关于这个主题的文档,但找不到它!
当前回答
我想为那些通过谷歌进入这个线程的人添加另一个选项。我需要完成这一点,但希望保留截断()重置的自动递增值。我也不想使用DB::任何东西,因为我想直接对模型对象进行操作。所以,我选择了这个:
Model::whereNotNull('id')->delete();
显然,列必须实际存在,但在标准的、开箱即用的Eloquent模型中,id列是存在的,并且永远不会为空。我不知道这是否是最好的选择,但它符合我的目的。
其他回答
在我的情况下,laravel 4.2删除所有行,但不截断表
DB:表(your_table) - > delete ();
MyModel::all()->delete()不起作用的原因是all()实际上触发了查询并返回了Eloquent对象的集合。
你可以使用截断方法,这适用于Laravel 4和5:
MyModel::truncate();
这将从表中删除所有行,而不记录单个行删除。
truncate的问题是它意味着立即提交, 因此,如果在事务中使用它,风险是您发现表为空。 最好的解决方案是使用删除
MyModel::query()->delete();
在Laravel 3中完成此操作的最佳方法似乎是使用Fluent接口截断表,如下所示
DB::query("TRUNCATE TABLE mytable");
MyModel:: truncate ();
在准将队伍中:
PHP工匠修补匠
then
职位:截断();