新网创想网站建设,新征程启航

为企业提供网站建设、域名注册、服务器等服务

php基于laravel框架如何实现批量插入

这篇文章主要介绍php基于laravel框架如何实现批量插入,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

网站建设哪家好,找创新互联公司!专注于网页设计、网站建设、微信开发、微信小程序定制开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了临川免费建站欢迎大家使用!

一、首先是查看laravel5.1手册

php基于laravel框架如何实现批量插入
     由图可知:laravel提供了insert插入数组的方法,也就是说,我们可以直接insert($array)实现批量插入的操作

二、先使用laravel的get()查询,获取数组对象,然后批量插入的操作

$ret = [];
    $create_red = new create_red();
    foreach($arr3 as $v){
      $delayDays = $v->delayDays;
      $workDays = $v->workDays;
      //获取当天时间戳的0点
      $now = strtotime(date('Y-m-d',time()));  ;
      $start = $now + $delayDays*86400;
      $start_at = date("Y-m-d H:i:s",$start);
      $end =  $now + $delayDays*86400 + $workDays*86400;
      $end_at = date('Y-m-d H:i:s',$end);
      $created_at = date("Y-m-d H:i:s",$now);
      $ret[] = [
        'uid'=>$uid,
        'status'=>1,
        'title'=>$v->title,
        'desc'=>$v->desc,
        'discount'=>$v->discount,
        'minprice'=>$v->minprice,
        'imgurl'=>$v->imgurl,
        'start_at'=>$start_at,
        'end_at'=>$end_at,
      ];
    }
    //往数据库批量插入数据
    $result = $create_red::insert($ret);
    if(!$result){
      DB::rollBack();
      return MyResponse::error(9006,'兑换优惠券失败');
    }

1、新建一个空数组

2、循环查询到的arrarr,并且循环向空数组arr,并且循环向空数组ret中插入数据,形成正确的数组格式

3、实例化数据表的model类

4、使用model::insert($array)的方法批量插入

5、结果是OK的,批量插入成功

三、批量生成兑换码之后的批量插入

先上代码:

 $num = 200;
    $codeArr = [];
    for($i=0;$i<$num;$i++){
      $code = EventCode::rand_str(8);
      $codeArr[$i]['code'] = $code;
    }
    /*var_dump($codeArr);
    exit;*/
    $event = new EventCode();
    $arr = $event::insert($codeArr);
    if(!$arr){
      return MyResponse::error('生成兑换码失败');
    }

1、新建一个空数组

2、循环生成兑换码,并写入数组

3、打印数组,数组显示正常之后,利用insert()方法插入

4、这里的插入效果也是OK的,

利用laravel自带的insert实现批量插入的效率还是可以的,只不过楼主插入的量少,也没有具体实现过性能这块。以后有发现的话就再写出来分享给大家。

以上是“php基于laravel框架如何实现批量插入”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!


当前名称:php基于laravel框架如何实现批量插入
分享网址:http://wjwzjz.com/article/ppsesj.html
在线咨询
服务热线
服务热线:028-86922220
TOP