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

 所属分类:php教程

 浏览:103次-  评论: 0次-  更新时间:2022-05-31
描述:这是一篇php教程 如何解决Laravel修改数据与原数据一样,导致没有执行sql的问题的说明内容,如果你想学习查找类似的文章,可以进入php教程...
这是一篇php教程 如何解决Laravel修改数据与原数据一样,导致没有执行sql的问题的说明内容,如果你想学习查找类似的文章,可以进入php教程获得最新优质资料。

下面由Laravel教程栏目给大家介绍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 有几个?
答案: 一个都没有。

原因

代码极简单

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

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

扯淡

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

以上就是如何解决Laravel修改数据与原数据一样,导致没有执行sql的问题的详细内容,更多请关注zzsucai.com其它相关文章!

 标签:
积分说明:注册即送10金币,每日签到可获得更多金币,成为VIP会员可免金币下载! 充值积分充值会员更多说明»

讨论这个素材(0)回答他人问题或分享使用心得奖励金币

〒_〒 居然一个评论都没有……

表情  文明上网,理性发言!