在使用yii2开发项目时,有时候会遇到这样的情况:
向后台发送多条数据,其中一些数据已经存在记录,只需要对其部分字段的值进行修改;而另一部分的数据则需要新添加进去.
这就需要对添加的数据进行判断,其中一些执行update,剩下的执行insert
代码如下,不对的地方请指教:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
//批量更新,并将需要批量插入的数据放入数组中 foreach ( $goods as $k => $v ) { if (yourModel::updateAllCounters( [ 'goods_num' => $v ], [ 'goods_id' => $k , 'user_id' => $id ] )) { 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(); } |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.yiichina.com/tutorial/1068