如何使用 Laravel 4.1 根据 id 或对象数组执行批量删除?
我只是想知道这是否可能。
我知道当你有多行要插入时,你可以建立一个数组并做这样的事情:
DB::table('some_table')->insert($array);
但据我所知,对删除做同样的事情似乎是不可能的,我想知道是否有人知道一种方法来做这样的事情:
DB::table('some_table')->delete($array);
我只是想知道这是否可能。
我知道当你有多行要插入时,你可以建立一个数组并做这样的事情:
DB::table('some_table')->insert($array);
但据我所知,对删除做同样的事情似乎是不可能的,我想知道是否有人知道一种方法来做这样的事情:
DB::table('some_table')->delete($array);
在 Laravel 4.1 中删除记录的多种方法
1)当您要从数据库中删除记录时,只需调用delete方法:
$affected = DB::table('users')->where('id', '=', 1)->delete();
2) 想要通过 ID 快速删除记录?没关系。只需将 ID 传递到 delete 方法中:
$affected = DB::table('users')->delete(1);
3)如果要一次按id删除多个记录,请在数组中传递其id - 使用以下命令
$users_to_delete = array(1, 2, 3);
DB::table('users')->whereIn('id', $users_to_delete)->delete();
4)如果要一次按id删除多个记录,请传递用户数组 - 使用以下命令
//(case A) User fields indexed by number 0,1,2..
$users_to_delete = array(
'0'=> array('1','Frank','Smith','Whatever'),
'1'=> array('5','John','Johnson','Whateverelse'),
);
$ids_to_delete = array_map(function($item){ return $item[0]; }, $users_to_delete);
DB::table('users')->whereIn('id', $ids_to_delete)->delete();
//(case B) User fields indexed by key
$users_to_delete = array(
'0'=> array('id'=>'1','name'=>'Frank','surname'=>'Smith','title'=>'Whatever'),
'1'=> array('id'=>'5','name'=>'John','surname'=>'Johnson','title'=>'Whateverelse'),
);
$ids_to_delete = array_map(function($item){ return $item['id']; }, $users_to_delete);
DB::table('users')->whereIn('id', $ids_to_delete)->delete();
5) 按键删除现有模型
User::destroy(1);
User::destroy(array(1, 2, 3));
User::destroy(1, 2, 3);
6)当然,您也可以对一组模型运行删除查询:
$affectedRows = User::where('votes', '>', 100)->delete();