Ответ 1
Многие способы удаления записей в Laravel 4.1
1) Если вы хотите удалить записи из своей базы данных, просто вызовите метод delete:
$affected = DB::table('users')->where('id', '=', 1)->delete();
2) Хотите быстро удалить запись по ее идентификатору? Нет проблем. Просто передайте идентификатор в метод удаления:
$affected = DB::table('users')->delete(1);
3) Если вы хотите удалить сразу несколько записей по 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();