博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHP框架 Laravel Eloquent ORM 批量插入数据 && 批量更新目前没有
阅读量:5947 次
发布时间:2019-06-19

本文共 2382 字,大约阅读时间需要 7 分钟。

foreach ($products as $v=>$a){ $count[] = array('product_name' => $a['name'], 'product_weight' => $a['weight'], 'product_id' => $a['pid'], 'product_price' => $a['price'], 'order_id' => $order->id, 'card_phone' => $user->phone);}CountOrder::insert($count);

在使用 laravel 的批量插入数据时,

插入的数据的创建时间却都是 0000000;

图片描述

创建时间 和 更新时间字段 如何正常保存呢 ,难道也要在数组里面写入吗?

 

 

 

 

框架封装好的方法目前是没有的,但是随手google了一下,在stackoverflow上看到一个和你的这个问题非常匹配的回答,以下复制于stackoverflow,原链接。

I have created My Custom function for Multiple Update like update_batch in CodeIgniter.
Just place this function in any of your model or you can create helper class and place this function in that class:

//test data/*$multipleData = array(   array(      'title' => 'My title' ,      'name' => 'My Name 2' ,      'date' => 'My date 2'   ),   array(      'title' => 'Another title' ,      'name' => 'Another Name 2' ,      'date' => 'Another date 2'   ))*//* * ---------------------------------- * update batch  * ---------------------------------- *  * multiple update in one query * * tablename( required | string ) * multipleData ( required | array of array ) */static function updateBatch($tableName = "", $multipleData = array()){    if( $tableName && !empty($multipleData) ) {        // column or fields to update        $updateColumn = array_keys($multipleData[0]);        $referenceColumn = $updateColumn[0]; //e.g id        unset($updateColumn[0]);        $whereIn = "";        $q = "UPDATE ".$tableName." SET ";         foreach ( $updateColumn as $uColumn ) {            $q .=  $uColumn." = CASE ";            foreach( $multipleData as $data ) {                $q .= "WHEN ".$referenceColumn." = ".$data[$referenceColumn]." THEN '".$data[$uColumn]."' ";            }            $q .= "ELSE ".$uColumn." END, ";        }        foreach( $multipleData as $data ) {            $whereIn .= "'".$data[$referenceColumn]."', ";        }        $q = rtrim($q, ", ")." WHERE ".$referenceColumn." IN (".  rtrim($whereIn, ', ').")";        // Update          return DB::update(DB::raw($q));    } else {        return false;    }}

It will Produces:

UPDATE `mytable` SET `name` = CASEWHEN `title` = 'My title' THEN 'My Name 2'WHEN `title` = 'Another title' THEN 'Another Name 2'ELSE `name` END,`date` = CASE WHEN `title` = 'My title' THEN 'My date 2'WHEN `title` = 'Another title' THEN 'Another date 2'ELSE `date` ENDWHERE `title` IN ('My title','Another title')

 

 

转载地址:http://rzbxx.baihongyu.com/

你可能感兴趣的文章
JS敏感信息泄露:不容忽视的WEB漏洞
查看>>
分布式memcached服务器代理magent安装配置(CentOS6.6)
查看>>
Create Volume 操作(Part III) - 每天5分钟玩转 OpenStack(52)
查看>>
tomcat 8.0虚拟机配置文档
查看>>
pxc群集搭建
查看>>
JS中加载cssText延时
查看>>
常用的脚本编程知识点
查看>>
计算机网络术语总结4
查看>>
新手小白 python之路 Day3 (string 常用方法)
查看>>
soapUI的简单使用(webservice接口功能测试)
查看>>
框架 Hibernate
查看>>
python-while循环
查看>>
手机端上传图片及java后台接收和ajaxForm提交
查看>>
【MSDN 目录】C#编程指南、C#教程、ASP.NET参考、ASP.NET 4、.NET Framework类库
查看>>
jquery 怎么触发select的change事件
查看>>
angularjs指令(二)
查看>>
<气场>读书笔记
查看>>
领域驱动设计,构建简单的新闻系统,20分钟够吗?
查看>>
web安全问题分析与防御总结
查看>>
React 组件通信之 React context
查看>>