Как массово удалить строки в таблице базы данных, которых нет в массиве, используя Laravel 4.2

Я хотел бы удалить строки в моей таблице, которых нет в массиве. В следующем примере это приведет к массовому удалению строк, которые соответствуют $ cards_to_delete.

$cards_to_delete = array(1, 2, 3);
Collection::where('username', '=', $username)
->whereIn('id', $cards_to_delete)
->delete();

Как я могу сделать так, чтобы он удалял все, что НЕ в массиве? Что-то вроде этого:

$cards_to_keep = array(1, 2, 3);
Collection::where('username', '=', $username)
->whereIn('id', '!=', $cards_to_keep)
->delete();

2

Решение

Laravel обеспечивает ->whereNotIn() метод также:

$cards_to_keep = array(1, 2, 3);
Collection::where('username', '=', $username)
->whereNotIn('id', $cards_to_keep)
->delete();
4

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]