数据库记录锁表锁实际研究笔记 --- MSSQLSERVER

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介: 直切主题 现有一张表 table : ChenJi ID, DanWeiID,  Name,  ChenJi   表中记录 ID  DanWeiID    Name      ChenJi --- ----------- --------- --------- 1   1        ...

直切主题

现有一张表

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  可以执行

 

 研究发现如果在一个表中进行了开启事务执行更新语句并用了索引字段做条件,会对这个表的条件对应的记录select ,update,delete进行排斥锁定,是其他连接中还可以进行insert 该表,其他的记录还可以正常的操作

 

Flag Counter

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
1月前
|
SQL 存储 关系型数据库
数据库的行级锁与表锁?
表锁:存储引擎在SQL数据读写请求前对涉及的表加锁,分共享读锁和独占写锁,读锁阻塞写,写锁阻塞读写,易发锁冲突,并发性低。行级锁:InnoDB支持,通过索引加锁,提高并发性,但可能引起死锁,需注意索引使用,适用于避免不可重复读场景。
62 21
|
3月前
|
SQL NoSQL 数据库
Cassandra数据库与Cql实战笔记
Cassandra数据库与Cql实战笔记
46 1
Cassandra数据库与Cql实战笔记
|
3月前
|
存储 关系型数据库 MySQL
MySQL数据库锁:共享锁和独占锁
本文详细介绍了`InnoDB`存储引擎中的两种行级别锁:共享锁(S锁)与排他锁(X锁)。通过具体示例展示了这两种锁的工作机制及其在`InnoDB`与`MyISAM`引擎中的表现差异。文章还提供了锁的兼容性矩阵,帮助读者更好地理解锁之间的互斥关系。最后总结了两种锁的特点及适用场景。适合希望深入了解`MySQL`并发控制机制的读者阅读。
120 1
|
4月前
|
SQL 关系型数据库 MySQL
学成在线笔记+踩坑(3)——【内容模块】课程分类查询、课程增改删、课程计划增删改查,统一异常处理+JSR303校验
课程分类查询、课程新增、统一异常处理、统一封装结果类、JSR303校验、修改课程、查询课程计划、新增/修改课程计划
学成在线笔记+踩坑(3)——【内容模块】课程分类查询、课程增改删、课程计划增删改查,统一异常处理+JSR303校验
|
4月前
|
前端开发 应用服务中间件 API
|
4月前
|
SQL 安全 Java
探索研究Servlet 数据库访问
【9月更文挑战第28天】
40 0
|
5月前
|
SQL 关系型数据库 数据库连接
探索研究Ruby 数据库访问
【8月更文挑战第31天】
43 1
|
5月前
|
SQL 存储 关系型数据库
"MySQL增列必锁表?揭秘InnoDB在线DDL,让你的数据库操作飞一般,性能无忧!"
【8月更文挑战第11天】在数据库领域,MySQL凭借其稳定高效的表现深受开发者喜爱。对于是否会在给数据表添加列时锁表的问题,MySQL的行为受版本、存储引擎等因素影响。从5.6版起,InnoDB支持在线DDL,可在改动表结构时保持表的可访问性,避免长时间锁表。而MyISAM等则需锁表完成操作。例如,在使用InnoDB的表上运行`ALTER TABLE users ADD COLUMN email VARCHAR(255);`时,通常不会完全锁表。虽然在线DDL提高了灵活性,但复杂操作或大表变更仍可能暂时影响性能。因此,进行结构变更前应评估其影响并择机执行。
88 6
|
5月前
|
SQL 数据库
无法获得数据库 'model' 上的排他锁。请稍后重试该操作
无法获得数据库 'model' 上的排他锁。请稍后重试该操作
107 0
|
6月前
数据库系统工程师考点笔记
数据库系统工程师考点笔记
496 0