Eloquentupdate()防止脏数据更新指南
哈喽!大家好,很高兴又见面了,我是golang学习网的一名作者,今天由我给大家带来一篇《Eloquent update() 方法详解:防止脏数据更新》,本文主要会讲到等等知识点,希望大家一起学习进步,也欢迎大家关注、点赞、收藏、转发! 下面就一起来看看吧!

Eloquent update() 方法的默认行为解析
在使用 Eloquent ORM 进行数据更新时,开发者常会遇到一个不符合直觉的现象:当通过模型实例调用 update() 方法并传入特定字段进行更新时,模型实例上在此之前被修改但未传入 update() 方法的“脏”属性也可能一并被更新到数据库中。
考虑以下代码示例:
$user = User::find(1); // 从数据库加载用户 $user->is_admin = 1; // 修改了 is_admin 属性,但尚未保存 $user->update(['first_name' => 'Alex']); // 意图只更新 first_name // 结果:is_admin 字段也可能被更新为 1!
为什么会发生这种情况?原因在于 Eloquent Model 类的 update() 方法的内部实现。根据其源代码定义,update() 方法首先会调用 fill() 方法将传入的属性填充到模型实例中,然后紧接着调用 save() 方法。
/**
* Update the model in the database.
*
* @param array $attributes
* @param array $options
* @return bool
*/
public function update(array $attributes = [], array $options = [])
{
if (! $this->exists) {
return false;
}
return $this->fill($attributes)->save($options);
}save() 方法的职责是保存模型实例的所有“脏”属性(即与从数据库加载时或上次保存后相比发生变化的属性)到数据库。因此,当 update() 方法被调用时,它不仅会保存传入 attributes 数组中的字段,还会将模型实例中所有在 update() 调用之前被修改过的其他属性一并保存。在上述示例中,$user->is_admin = 1; 这行代码已经将 is_admin 标记为“脏”属性,因此在 update(['first_name' => 'Alex']) 执行时,is_admin 也会被 save() 方法更新到数据库。
解决方案:使用查询构建器进行精确更新
为了避免这种意外的副作用,确保只更新指定的字段,推荐的方法是绕过模型实例的 save() 行为,直接使用 Eloquent 的查询构建器(Query Builder)进行更新。这样可以精确控制哪些字段会被修改。
$user = User::find(1); // 从数据库加载用户 $user->is_admin = 1; // 此时模型实例的 is_admin 属性已被修改 // 使用查询构建器直接更新数据库,只影响指定的字段 User::whereKey($user->getKey())->update(['first_name' => 'Alex']); // 此时数据库中只有 first_name 被更新,is_admin 保持不变(除非之前就是1) // 但请注意,内存中的 $user 实例的 first_name 仍是旧值,is_admin 仍是 1
重要注意事项:模型实例与数据库同步
当使用 User::whereKey($user->getKey())->update(...) 这种方式进行更新时,数据库中的记录会被修改,但内存中 $user 变量所引用的模型实例并不会自动更新以反映这些变化。如果后续操作依赖于 $user 实例的最新状态,你需要手动同步它。
有两种主要的同步方式:
手动更新模型实例的属性: 如果你知道哪些字段被更新了,可以直接设置模型实例的属性。同时,为了确保模型实例的“脏”状态正确,可以调用 setOriginalAttribute() 来更新其原始属性值。
$user = User::find(1); $user->is_admin = 1; User::whereKey($user->getKey())->update(['first_name' => 'Alex']); // 手动更新内存中的模型实例 $user->first_name = 'Alex'; // 可选:更新原始属性以清除其“脏”状态,防止后续意外保存 $user->setOriginalAttribute('first_name', 'Alex'); // 此时 $user->first_name 已经是 'Alex'刷新模型实例: 如果你不确定哪些字段被更新了,或者更新逻辑复杂,可以使用 refresh() 方法重新从数据库加载模型实例的最新数据。这会产生一次额外的数据库查询。
$user = User::find(1); $user->is_admin = 1; User::whereKey($user->getKey())->update(['first_name' => 'Alex']); // 重新从数据库加载最新数据到模型实例 $user->refresh(); // 此时 $user->first_name 已经是 'Alex',is_admin 保持数据库中的原值
请注意,虽然 refresh() 会产生额外查询,但在某些复杂场景下,它可能是最稳健的同步方式。
总结
Eloquent 的 update() 方法在模型实例上调用时,会将其内部所有已修改(脏)的属性一并保存。如果需要精确控制只更新传入的特定字段,而不触及模型实例上其他已修改的属性,则应使用查询构建器(例如 Model::whereKey($id)->update([...]))进行更新。在使用查询构建器更新后,务必记住手动同步内存中的模型实例,或者通过 refresh() 方法重新加载以确保数据一致性。理解这些细微差别对于编写健壮和可预测的 Eloquent 代码至关重要。
今天关于《Eloquentupdate()防止脏数据更新指南》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
Pandas条件替换技巧全解析
- 上一篇
- Pandas条件替换技巧全解析
- 下一篇
- CSS中vw是什么单位?详解vw含义
-
- 文章 · php教程 | 1小时前 |
- Laravel测验评分for循环索引问题解决
- 251浏览 收藏
-
- 文章 · php教程 | 1小时前 |
- LaravelDusk剪贴板权限设置教程
- 186浏览 收藏
-
- 文章 · php教程 | 2小时前 |
- PHP多维数组条件赋值方法解析
- 448浏览 收藏
-
- 文章 · php教程 | 2小时前 |
- Laravel路由控制器工作原理解析
- 488浏览 收藏
-
- 文章 · php教程 | 2小时前 |
- XAMPP端口冲突解决全攻略
- 129浏览 收藏
-
- 文章 · php教程 | 3小时前 |
- PHP信号量与共享内存使用教程
- 323浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3180次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 3391次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 3420次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 4526次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 3800次使用
-
- PHP技术的高薪回报与发展前景
- 2023-10-08 501浏览
-
- 基于 PHP 的商场优惠券系统开发中的常见问题解决方案
- 2023-10-05 501浏览
-
- 如何使用PHP开发简单的在线支付功能
- 2023-09-27 501浏览
-
- PHP消息队列开发指南:实现分布式缓存刷新器
- 2023-09-30 501浏览
-
- 如何在PHP微服务中实现分布式任务分配和调度
- 2023-10-04 501浏览

