MySql 更新一行数据 只更新到一部分字段 有字段没更新到

$order = Db::name('order')->field('id,kcid,user_id,type,status,paytime,o2o')->where(['ordersn' => $data['orderId']])->lock(true)->where('status', '0')->find();//查询加了锁

  $upd = ['status' => '1', 'paytime' => time(), 'transaction_id' => $transaction_id,'cmbOrderId'=>$cmbOrderId];
 Db::name('order')->where('paytime', 0)->where('id', $order_id)->update($upd);//更新

transaction_id更新到了, cmbOrderId却未更新,查看日志确保两个都是有数据,且在前面打开了事务
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 4

可否看一下 transaction_idcmbOrderId 这两个字段更新前和更新后的值?还有你这里的完整代码。

还有你的 ->name()->field() 都是哪来的方法?这个 ->find() 用法也不对啊,不传 id 值的话会报错的。报错以后,看下是不是事务后面进行了 transaction_id 字段的修改。

3年前 评论
aa24615 3年前
LiamHao (作者) 3年前
aa24615

你这是 tp 的吧

3年前 评论

是不是批量赋值的问题呀。你设置一下批量赋值!!

3年前 评论

已解决 ,有两个地方同时修改了,另一个地方未修改到 cmbOrderId

3年前 评论