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 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
讨论数量: 4

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

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

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

你这是tp的吧

3年前 评论

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

3年前 评论

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

3年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!