如何根据ids或对象数组使用Laravel 4.1执行批量删除?

arr*_*nfr 19 php arrays orm eloquent laravel-4

我只是想知道它是否可能.

我知道当你要插入多行时,你可以构建一个数组并执行以下操作:

DB::table('some_table')->insert($array);
Run Code Online (Sandbox Code Playgroud)

但据我所知,删除操作似乎不太可能,我想知道是否有人知道如何做某些事情:

DB::table('some_table')->delete($array);
Run Code Online (Sandbox Code Playgroud)

Gad*_*oma 43

在Laravel 4.1中删除记录的许多方法

1)如果要从数据库中删除记录,只需调用delete方法:

$affected = DB::table('users')->where('id', '=', 1)->delete();
Run Code Online (Sandbox Code Playgroud)

2)想要通过ID快速删除记录?没问题.只需将ID传递给delete方法:

$affected = DB::table('users')->delete(1);
Run Code Online (Sandbox Code Playgroud)

3)如果要一次删除id的多个记录,将它们的ID传递给数组 - 请使用以下命令

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

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(); 
Run Code Online (Sandbox Code Playgroud)

5)按键删除现有模型

User::destroy(1);
User::destroy(array(1, 2, 3));
User::destroy(1, 2, 3);
Run Code Online (Sandbox Code Playgroud)

6)当然,您也可以在一组模型上运行删除查询:

$affectedRows = User::where('votes', '>', 100)->delete();
Run Code Online (Sandbox Code Playgroud)