Yii2 批量插入、更新數(shù)據(jù)實(shí)例
在使用yii2開(kāi)發(fā)項(xiàng)目時(shí),有時(shí)候會(huì)遇到這樣的情況:
向后臺(tái)發(fā)送多條數(shù)據(jù),其中一些數(shù)據(jù)已經(jīng)存在記錄,只需要對(duì)其部分字段的值進(jìn)行修改;而另一部分的數(shù)據(jù)則需要新添加進(jìn)去.
這就需要對(duì)添加的數(shù)據(jù)進(jìn)行判斷,其中一些執(zhí)行update,剩下的執(zhí)行insert
代碼如下,不對(duì)的地方請(qǐng)指教:
//批量更新,并將需要批量插入的數(shù)據(jù)放入數(shù)組中
foreach($goods as $k => $v)
{
if(yourModel::updateAllCounters(
['goods_num' => $v],
['goods_id' => $k,'user_id' => $id]
))
{
continue;//如果已經(jīng)更新,則跳過(guò)此次循環(huán),到下一次
}
$data[] = [
'user_id' => $id,
'goods_id' => $k,
'goods_num' => $v,
'created_time' => $time,
]
}
//再執(zhí)行批量插入
if (isset($data))
{
Yii::$app->db->createCommand()
->batchInsert(yourModel::tableName(),['user_id','goods_id','goods_num','created_time'],
$data)
->execute();
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- yii框架結(jié)合charjs實(shí)現(xiàn)統(tǒng)計(jì)30天數(shù)據(jù)的方法
- yii 框架實(shí)現(xiàn)按天,月,年,自定義時(shí)間段統(tǒng)計(jì)數(shù)據(jù)的方法分析
- Yii統(tǒng)計(jì)不同類(lèi)型郵箱數(shù)量的方法
- Yii中的relations數(shù)據(jù)關(guān)聯(lián)查詢(xún)及統(tǒng)計(jì)功能用法詳解
- 解析yii數(shù)據(jù)庫(kù)的增刪查改
- Yii2框架數(shù)據(jù)庫(kù)簡(jiǎn)單的增刪改查語(yǔ)法小結(jié)
- Yii2.0高級(jí)框架數(shù)據(jù)庫(kù)增刪改查的一些操作
- yii框架表單模型使用及以數(shù)組形式提交表單數(shù)據(jù)示例
- Yii實(shí)現(xiàn)MySQL多數(shù)據(jù)庫(kù)和讀寫(xiě)分離實(shí)例分析
- Yii+MYSQL鎖表防止并發(fā)情況下重復(fù)數(shù)據(jù)的方法
- Yii實(shí)現(xiàn)多數(shù)據(jù)庫(kù)主從讀寫(xiě)分離的方法
- yii框架結(jié)合charjs統(tǒng)計(jì)上一年與當(dāng)前年數(shù)據(jù)的方法示例
相關(guān)文章
laravel 修改記住我功能的cookie保存時(shí)間的方法
今天小編就為大家分享一篇laravel 修改記住我功能的cookie保存時(shí)間的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10
CodeIgniter自定義控制器MY_Controller用法分析
這篇文章主要介紹了CodeIgniter自定義控制器MY_Controller用法,結(jié)合實(shí)例形式分析了CodeIgniter自定義控制器MY_Controller的定義與使用技巧,需要的朋友可以參考下2016-01-01
創(chuàng)建配置文件 用PHP寫(xiě)出自己的BLOG系統(tǒng) 2
今天做博客安裝程序,首先做的是配置文件的創(chuàng)建。2010-04-04
仿Aspnetpager的一個(gè)PHP分頁(yè)類(lèi)代碼 附源碼下載
最近正在學(xué)習(xí)php,想拿一些demo來(lái)練習(xí)一下,想起前段時(shí)間自己用.net寫(xiě)的仿Aspnetpager控件的分頁(yè)類(lèi),就琢磨著用PHP來(lái)實(shí)現(xiàn)仿aspnetpager的分頁(yè)功能,隨便復(fù)習(xí)下2012-10-10
Zend Framework教程之響應(yīng)對(duì)象的封裝Zend_Controller_Response實(shí)例詳解
這篇文章主要介紹了Zend Framework教程之響應(yīng)對(duì)象的封裝Zend_Controller_Response用法,結(jié)合實(shí)例形式詳細(xì)分析了響應(yīng)對(duì)象的邏輯原理與相關(guān)使用技巧,需要的朋友可以參考下2016-03-03

