1

我有下面的数组(这个数组中有50个元素。所以下面的mysql查询会触发50次。)要在数据库中更新

$array = [['id'=>1,'result'=>'21.25'],['id'=>2,'result'=>'13.03']]// ... up to 50 elements in this array. so below mysql query fires 50 times.

我正在这样做。

foreach ($array as $key => $value) {
    $postArray =  ['result' => $value['result']];
    DB::table('table')->where('id',$value['id'])->update($postArray);
}

问题:是否可以在一个查询中合并所有内容?

我试过这样但没有工作,

giving error `"errormsg":"Database error!! preg_replace(): Parameter mismatch, pattern is a string

而替换是一个数组“`

foreach ($array as $key => $value) {
    $postArray[] =  [
        'id' => $value['id'],
        'result' => $value['result']
    ];
}
DB::table('table')->update($postArray);
4

1 回答 1

0

您可以使用 whereIn() 函数来更新具有相同数据的多行。

$idArray = array(1, 2, 3);
$postArray =  ['result' => $value['result']];
DB::table('table')->whereIn('id',$idArray)->update($postArray);

注意:从代码语法来看,我假设您使用的是 Laravel 框架。所以解决方案适用于 Laravel。如果您使用的是其他框架,您可以检查类似的方法。

于 2016-04-23T09:59:53.160 回答