web-dev-qa-db-fra.com

Comment puis-je effectuer une suppression en masse à l'aide de Laravel 4.1, basé sur un tableau d'identifiants ou d'objets?

Je voulais juste savoir si c'était possible.

Je sais que lorsque vous avez plusieurs lignes à insérer, vous pouvez simplement créer un tableau et faire quelque chose comme:

DB::table('some_table')->insert($array);

Mais d'après ce que j'ai lu, faire la même chose pour la suppression ne semble pas possible, j'aimerais savoir si quelqu'un connaît un moyen de faire quelque chose comme:

DB::table('some_table')->delete($array);
19
arrigonfr

De nombreuses façons de supprimer des enregistrements dans Laravel 4.1

1) Lorsque vous souhaitez supprimer des enregistrements de votre base de données, appelez simplement la méthode de suppression:

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

2) Vous souhaitez supprimer rapidement un enregistrement par son ID? Aucun problème. Passez simplement l'ID dans la méthode de suppression:

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

) Si vous souhaitez supprimer plusieurs enregistrements par identifiant à la fois, en passant leurs identifiants dans un tableau - utilisez ce qui suit

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

4) Si vous souhaitez supprimer plusieurs enregistrements par identifiant à la fois, en passant un tableau d'utilisateurs - utilisez ce qui suit

        //(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) Suppression d'un modèle existant par clé

User::destroy(1);
User::destroy(array(1, 2, 3));
User::destroy(1, 2, 3);

6) Bien sûr, vous pouvez également exécuter une requête de suppression sur un ensemble de modèles:

$affectedRows = User::where('votes', '>', 100)->delete();
43
Gadoma