数据库记录锁表锁实际研究笔记---MSSQLSERVER
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了数据库记录锁表锁实际研究笔记---MSSQLSERVER,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3715字,纯文字阅读大概需要6分钟。
内容图文
![数据库记录锁表锁实际研究笔记---MSSQLSERVER](/upload/InfoBanner/zyjiaocheng/546/662a8a5eba2646bd9cfba588d29c1663.jpg)
直切主题 现有一张表 table : ChenJi ID, DanWeiID, Name, ChenJi 表中记录 ID DanWeiID Name ChenJi --- ----------- --------- --------- 1 1 aa 91 2 1 bb 91 3 1 cc 33 4 2 dd 164 5 2 ee 155 6 2 ff 166 在查询分析器里面开两个连接 A连接 begin tran t
直切主题
现有一张表
table : ChenJi
ID, DanWeiID, Name, ChenJi
表中记录
ID DanWeiID Name ChenJi
--- ----------- --------- ---------
1 1 aa 91
2 1 bb 91
3 1 cc 33
4 2 dd 164
5 2 ee 155
6 2 ff 166
在查询分析器里面开两个连接
A连接
begin tran t1
insert into ChenJi (DanWeiID, Name, ChenJi) values (3, ‘张三', 98)
rollback tran t1
B连接
插入与锁
先开始A连接的事务,不急着结束事务
然后在B连接中 依次执行如下一些语句
1.insert into ChenJi (DanWeiID, Name, ChenJi) values (3, ‘李四', 99) 可以执行插入语句
2.select * from ChenJi 需要等待
3.select * from ChenJi where Name = 'aa' 需要等待
3.update ChenJi SET ChenJi = 91 WHERE Name = 'aa' 需要等待
4.delete from ChenJi where Name = 'aa' 需要等待
研究发现如果在一个表中进行了开启事务执行插入语句,会对这个表的select ,update,delete进行排斥锁定,但是其他连接中还可以进行insert 该表
更新与锁
在查询分析器里面开两个连接
A连接
begin tran t1
update ChenJi SET ChenJi = 91 WHERE Name = 'aa'
rollback tran t1
先开始A连接的事务,不急着结束事务
然后在B连接中 依次执行如下一些语句
1. update ChenJi SET ChenJi = 91 WHERE Name = 'aa' 需要等待
2.select * from ChenJi where Name = 'aa' 需要等待
3.select * from ChenJi where Name = 'bb' 需要等待
4.select * from ChenJi where ChenJi =0 需要等待
5.update ChenJi SET ChenJi = 91 WHERE Name = 'bb' 需要等待
6.delete from ChenJi where Name = 'bb'需要等待
7.insert into ChenJi (ID, DanWeiID, Name, ChenJi) values (100, 3, 'ymf', 98) 可以执行插入语句
研究发现如果在一个表中进行了开启事务执行更新语句,会对这个表的select ,update,delete进行排斥锁定,但是其他连接中还可以进行insert 该表
主键与锁
在查询分析器里面开两个连接
在ChenJi表上面加入主键ID int类型
A连接
begin tran t1
update ChenJi SET ChenJi = 91 WHERE ID = 1
rollback tran t1
先开始A连接的事务,不急着结束事务
然后在B连接中 依次执行如下一些语句
1. update ChenJi SET ChenJi = 91 WHERE Name = 'aa' 需要等待
2.select * from ChenJi where Name = 'aa' 需要等待
3.select * from ChenJi where ID = 1 需要等待 --因为name = ‘aa’
4.select * from ChenJi where ChenJi =0 需要等待
5.update ChenJi SET ChenJi = 91 WHERE Name = 'bb' 可以执行
6.delete from ChenJi where Name = 'bb' 可以执行
7.insert into ChenJi (ID, DanWeiID, Name, ChenJi) values (100, 3, 'ymf', 98) 可以执行语句
8.update ChenJi SET ChenJi = 91 WHERE ID = 2 可以执行
9.select * from ChenJi where ID = 2 可以执行
10.delete from ChenJi where ID = 2 可以执行
研究发现如果在一个表中进行了开启事务执行更新语句并用了主键做条件,会对这个表的主键对应的记录select ,update,delete进行排斥锁定,是其他连接中还可以进行insert 该表,其他的记录还可以正常的操作
索引锁
在查询分析器里面开两个连接
在ChenJi表上面对Name字段进行索引<不是唯一性的索引>, ID依旧是主键不是唯一性的索引>
A连接
begin tran t1
update ChenJi SET ChenJi = 91 WHERE name = ‘aa’
rollback tran t1
先开始A连接的事务,不急着结束事务
然后在B连接中 依次执行如下一些语句
1. update ChenJi SET ChenJi = 91 WHERE Name = 'aa' 需要等待
2.select * from ChenJi where Name = 'aa' 需要等待
3.select * from ChenJi where Name = 'bb' 可以执行
4.select * from ChenJi where ChenJi =0 需要等待
5.update ChenJi SET ChenJi = 91 WHERE Name = 'bb' 可以执行
6.delete from ChenJi where Name = 'bb' 可以执行
7.insert into ChenJi (ID, DanWeiID, Name, ChenJi) values (100, 3, 'ymf', 98) 可以执行语句
8.update ChenJi SET ChenJi = 91 WHERE ID = 2 可以执行
9.select * from ChenJi where ID = 2 可以执行
10.delete from ChenJi where ID = 2 可以执行
内容总结
以上是互联网集市为您收集整理的数据库记录锁表锁实际研究笔记---MSSQLSERVER全部内容,希望文章能够帮你解决数据库记录锁表锁实际研究笔记---MSSQLSERVER所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。