乐观锁和悲观锁在mysql数据库中有什么区别

P粉602998670
发布: 2025-10-21 18:54:01
原创
854人浏览过
悲观锁在操作前加锁,通过SELECT FOR UPDATE实现,适合写多高冲突场景;乐观锁在提交时检查版本号,适合读多写少场景,二者根据业务需求权衡选择。

乐观锁和悲观锁在mysql数据库中有什么区别

乐观锁和悲观锁是数据库中处理并发控制的两种策略,它们在实现方式、适用场景和性能表现上有明显区别。MySQL本身没有直接提供“乐观锁”或“悲观锁”的语法关键字,但可以通过具体机制来体现这两种思想。

悲观锁:假设冲突总会发生

悲观锁认为在操作数据的过程中,很可能会有其他事务修改同一数据,因此在访问数据时会先加锁,防止其他事务修改。

在MySQL中,通常通过 SELECT ... FOR UPDATESELECT ... LOCK IN SHARE MODE 来实现悲观锁,这些语句只能在事务中使用(如InnoDB引擎)。

举例:

开启事务后执行:

SELECT * FROM users WHERE id = 1 FOR UPDATE;
登录后复制

这条语句会锁定该行记录,直到当前事务结束,其他事务无法修改或加排他锁,从而保证数据安全。

适合场景:

  • 写操作频繁,冲突概率高
  • 数据一致性要求非常严格
  • 金融交易、库存扣减等

乐观锁:假设冲突很少发生

乐观锁认为大多数情况下不会发生并发冲突,因此在读取时不加锁。只有在更新时才会检查在此期间是否有其他事务修改过数据。

常见的实现方式是在表中增加一个版本号字段(version)或时间戳(timestamp)。每次更新时对比版本号,若不一致则说明数据已被修改,更新失败。

阿里云-虚拟数字人
阿里云-虚拟数字人

阿里云-虚拟数字人是什么? ...

阿里云-虚拟数字人2
查看详情 阿里云-虚拟数字人
举例:

更新用户余额时:

UPDATE users SET balance = 90, version = version + 1 
WHERE id = 1 AND version = 1;
登录后复制

如果返回影响行数为0,说明版本不匹配,其他事务已修改,当前操作需重试或提示失败。

适合场景:

  • 读多写少
  • 并发冲突较少
  • 如文章点赞、浏览量统计等

核心区别总结

加锁时机不同: 悲观锁在操作前就加锁,乐观锁在提交时才检查冲突。

性能表现: 悲观锁开销大,可能造成阻塞;乐观锁开销小,但在冲突频繁时会导致大量重试。

一致性保障: 悲观锁能更强地保证数据一致性,乐观锁依赖应用层逻辑处理失败情况。

基本上就这些,选择哪种方式要看业务对并发、性能和一致性的权衡。

以上就是乐观锁和悲观锁在mysql数据库中有什么区别的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号