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

                                                       

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

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

代码

$openid = "123"; // 微信openid User::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 有几个?
答案: 一个都没有。

原因

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

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

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

扯淡

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

© 版权声明
THE END
喜欢就支持一下吧
点赞5 分享