Как выполнить массовое удаление с использованием Laravel 4.1 на основе массива идентификаторов или объектов?

Я просто хотел узнать, возможно ли это.

Я знаю, когда у вас есть несколько строк для вставки, вы можете просто построить массив и сделать что-то вроде:

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) Хотите быстро удалить запись по ее идентификатору? Нет проблем. Просто передайте идентификатор в метод удаления:

 $affected = DB::table('users')->delete(1); 

3) Если вы хотите удалить сразу несколько записей по идентификатору, передав их идентификаторы в массиве, используйте следующие

 $users_to_delete = array(1, 2, 3); DB::table('users')->whereIn('id', $users_to_delete)->delete(); 

4) Если вы хотите удалить сразу несколько записей по идентификатору, передав массив пользователей, используйте следующие

  //(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();