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却未更新,查看日志确保两个都是有数据,且在前面打开了事务
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 4

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

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

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

你这是tp的吧

3年前 评论

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

3年前 评论

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

3年前 评论

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