Yii2 批量插入、更新数据实例

 更新时间:2017年03月15日 09:05:38   作者:hebo5485   我要评论
这篇文章主要介绍了Yii2 批量插入、更新数据实例的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。

在使用yii2开发项目时,有时候会遇到这样的情况:

向后台发送多条数据,其中一些数据已经存在记录,只需要对其部分字段的值进行修改;而另一部分的数据则需要新添加进去.

这就需要对添加的数据进行判断,其中一些执行update,剩下的执行insert

代码如下,不对的地方请指教:

//批量更新,并将需要批量插入的数据放入数组中

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();
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • laravel实现前后台路由分离的方法

    laravel实现前后台路由分离的方法

    今天小编就为大家分享一篇laravel实现前后台路由分离的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • Zend Framework入门教程之Zend_View组件用法示例

    Zend Framework入门教程之Zend_View组件用法示例

    这篇文章主要介绍了Zend Framework中Zend_View组件用法,结合实例形式简单分析了Zend_View组件视图操作的相关技巧与注意事项,需要的朋友可以参考下
    2016-12-12
  • yii的CURD操作实例详解

    yii的CURD操作实例详解

    这篇文章主要介绍了yii的CURD操作技巧,以实例形式详细分析了基于yii框架的增删改查的具体用法,非常具有实用价值,需要的朋友可以参考下
    2014-12-12
  • PHP中如何防止外部恶意提交调用ajax接口

    PHP中如何防止外部恶意提交调用ajax接口

    本文简单介绍如何防止外部恶意调用ajax接口,以达到节省流量,减轻服务器压力的目的。
    2016-04-04
  • Yii框架中memcache用法实例

    Yii框架中memcache用法实例

    这篇文章主要介绍了Yii框架中memcache用法,以实例形式分析了在Yii框架中加入memcache的具体操作方法,是非常实用的技巧,需要的朋友可以参考下
    2014-12-12
  • Zend Framework教程之Zend_Db_Table_Row用法实例分析

    Zend Framework教程之Zend_Db_Table_Row用法实例分析

    这篇文章主要介绍了Zend Framework教程之Zend_Db_Table_Row用法,详细讲述了Zend_Db_Table_Row的功能,并结合实例形式详细分析了Zend_Db_Table_Row操作数据的相关技巧,需要的朋友可以参考下
    2016-03-03
  • PHP书写格式详解(必看)

    PHP书写格式详解(必看)

    下面小编就为大家带来一篇PHP书写格式详解(必看)。小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-05-05
  • Laravel 5 框架入门(一)

    Laravel 5 框架入门(一)

    本文给大家介绍的是Laravel5框架入门的第一篇文章,主要给大家介绍些基础的知识,包括安装配置,数据库的建立与迁移,模型介绍,是篇非常不错的入门文章,这里推荐给大家。
    2015-04-04
  • Yii框架在页面输出执行sql语句以方便调试的实现方法

    Yii框架在页面输出执行sql语句以方便调试的实现方法

    这篇文章主要介绍了Yii框架在页面输出执行sql语句以方便调试的实现方法,涉及yiidebugtb的使用,是比较实用的技巧,需要的朋友可以参考下
    2014-12-12
  • 基于Laravel Auth自定义接口API用户认证的实现方法

    基于Laravel Auth自定义接口API用户认证的实现方法

    这篇文章主要给大家介绍了基于Laravel Auth自定义接口API用户认证的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-07-07

最新评论