您的位置 首页 php

如何解决Laravel修改数据与原数据一样,导致没有执行sql的问题

下面由Laravel教程栏目给大家介绍Laravel修改数据与原数据一样,导致没有执行sql的解决办法,希望对需要的朋友有所帮助!

代码

$openid = "123"; // 微信openidUser::WhereIn("id",['1','2','3'])->update([  'openid' => $openid]);$user = User::find(1);// 取消所有这个openid的绑定者User::Where(['openid' => $openid])->update([  'openid' => null]);// 给1号用户绑定openid$user->openid = $openid;$user->save();

问题: openid = 123 有几个?
答案: 一个都没有。

原因

代码极简单

getDirty 会返回 $useroriginal(查询出来的 不允许改变) 和 attributes(手动赋值的) 不同的地方,

最后发现属性都一样,所以 $user->save() 不会执行修改。

扯淡

微信绑定 的时候发现不对劲,还以为是 laravel 或者 mysqlbug

文章来源:智云一二三科技

文章标题:如何解决Laravel修改数据与原数据一样,导致没有执行sql的问题

文章地址:https://www.zhihuclub.com/26096.shtml

关于作者: 智云科技

热门文章

网站地图