0

0

悲观锁是什么?

Guanhui

Guanhui

发布时间:2020-06-28 09:52:59

|

5031人浏览过

|

来源于php中文网

原创

悲观锁指的是对数据被外界修改持保守态度,就是在数据处理过程中,将数据处于锁定状态,该功能需要依靠数据库提供的锁机制,否则即使在系统中实现了加锁机制,也无法保证外部系统不会修改数据。

悲观锁是什么?

锁的模式

LockMode.NONE

无锁机制

LockMode.READ

Hibernate在读取记录时自动获取锁

即共享锁:(Shared lock, S 锁),共享锁又称读锁。如果事务 T 获得了数据对象 A 上的共享锁(也就是说对 A 加上共享锁),那么其他事务只能获得 A 上的 共享锁(S 锁),而不能加排他锁(X 锁),直到 A 释放所有的共享锁。获准共享锁的事务只能读数据,不能修改数据。

LockMode.WRITE

Hibernate在insert获者update记录时自动获取锁

即排他锁:(Exclusive lock, X 锁),排他锁又称写锁。如果事务 T 获得了数据 A 上的排他锁,那么 T 既可以读又可以写 A,但是在 T 释放 A 上的 X 锁之前,其他事务既不能获得 A 上的共享锁,也不能获得 A 上的排他锁。

LockMode.UPGRADE

如果数据库系统支持悲观锁(如Oracle和MySQL),就执行select…for update语句(行级锁住,其他事务不能对其进行update、insert和delete语句),如果数据库不支持悲观锁(如Sybase),就执行普通的select语句。

LockMode.UPGRADE_NOWAIT

和LockMode.UPGRADE具有相同的功能。此外,对于Oracle数据库执行select…for update nowait语句。”nowait”表示如果执行该select语句的事务不能立刻获得悲观锁,那么不会等待其他事务释放锁,而是立刻抛出一个锁定异常。

家电小商城网站源码1.0
家电小商城网站源码1.0

家电公司网站源码是一个以米拓为核心进行开发的家电商城网站模板,程序采用metinfo5.3.9 UTF8进行编码,软件包含完整栏目与数据。安装方法:解压上传到空间,访问域名进行安装,安装好后,到后台-安全与效率-数据备份还原,恢复好数据后到设置-基本信息和外观-电脑把网站名称什么的改为自己的即可。默认后台账号:admin 密码:132456注意:如本地测试中127.0.0.1无法正常使用,请换成l

下载

锁的演示

注意:锁只对一次事务中操作的数据对象起作用,并不是对整个数据库起作用而将整个数据库锁住。

打开两个SQL命令操作行界面,这两个界面可以代表两个事务 T1 和 T2。我们先在两个界面中分别执行命令:start transaction;

在事务 T1 中在数据库中查询学号为 “2015” 的学生信息并对操作的数据加上悲观锁:select * from stu_info where stu_no=”2015” for update;。此时我们能查询到对应的信息。

“for update” 就表示加上悲观锁。此次查询完并不提交事务,也就是说还未释放锁

在事务 T2 中在数据库中查询学号为 “2016” 的学生信息并对操作的数据加上悲观锁:select * from stu_info where stu_no=”2016” for update;。此时我们也能查询到对应的信息。

尚不提交事务

在事务 T2 中在数据库中查询学号为 “2015” 的学生信息,此次做普通的 select 查询,不加锁:select * from stu_info where stu_no=”2015”;。此时我们也能查询到对应的信息。

尚不提交事务

在事务 T2 中尝试查询数据库中学号为 “2015” 的学生信息并对操作的数据加上悲观锁:select * from stu_info where stu_no=”2015” for update;。此时我们能发现,并未显示相关的信息,而是在等待中。当我们提交事务 T1 时(即:commit),数据对象 “2015” 释放 T1 中的悲观锁,T2 事务才能查询到相关的信息并获取到悲观锁。

如果我们换一下步骤5。在刚才的第五步中,我们在事务 T1 中修改学号为 “2016”学生信息但是不加悲观锁,因为此前我们在 事务 T2 中对该记录加了悲观锁还未释放,所以,只有等 T2 提交后才能修改成功。

推荐教程:《MySQL教程

相关文章

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
云朵浏览器入口合集
云朵浏览器入口合集

本专题整合了云朵浏览器入口合集,阅读专题下面的文章了解更多详细地址。

0

2026.01.20

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

20

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

62

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

87

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

39

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.19

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

19

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

160

2026.01.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 802人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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