Yii2批量插⼊、更新数据实例
在使⽤yii2开发项⽬时,有时候会遇到这样的情况:
向后台发送多条数据,其中⼀些数据已经存在记录,只需要对其部分字段的值进⾏修改;⽽另⼀部分的数据则需要新添加进去.这就需要对添加的数据进⾏判断,其中⼀些执⾏update,剩下的执⾏insert
代码如下,不对的地⽅请指教:
//批量更新,并将需要批量插⼊的数据放⼊数组中
foreach($goods as $k => $v)
{
if(yourModel::updateAllCounters(
['goods_num' => $v],
['goods_id' => $k,'user_id' => $id]
app开发实例
))
{
continue;//如果已经更新,则跳过此次循环,到下⼀次
}
$data[] = [
'user_id' => $id,
'goods_id' => $k,
'goods_num' => $v,
'created_time' => $time,
]
}
//再执⾏批量插⼊
if (isset($data))
{
Yii::$app->db->createCommand()
->batchInsert(yourModel::tableName(),['user_id','goods_id','goods_num','created_time'],
$data)
->execute();
}
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。