gpt4 book ai didi

php - 如何使用 Laravel 4.1 基于 id 或对象数组执行批量删除?

转载 作者:IT王子 更新时间:2023-10-29 00:00:54 27 4
gpt4 key购买 nike

我只是想知道是否可能。

I know when you have multiple rows to insert, you can just build an array and do something like:

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) 想通过 ID 快速删除记录?没问题。只需将 ID 传递给 delete 方法即可:

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

3) 如果您想一次按 id 删除多条记录,请将它们的 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();

关于php - 如何使用 Laravel 4.1 基于 id 或对象数组执行批量删除?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23624630/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com