SQL Server笔记 -- 第63章:事务隔离级别

63.1 已提交读(Read Committed)

sql 复制代码
SET TRANSACTION ISOLATION LEVEL READ COMMITTED

这是第二宽松的隔离级别,可防止脏读。其行为取决于 READ_COMMITTED_SNAPSHOT 设置:

  • 设为 OFF(默认)时,事务使用共享锁阻止其他事务修改当前事务正在读取的行,同时阻止当前事务读取正在被其他事务修改的行。
  • 设为 ON 时,可使用 READCOMMITTEDLOCK 表提示请求共享锁而非行版本控制。

注意:READ COMMITTED 是 SQL Server 的默认隔离级别。

63.2 什么是"脏读"?

脏读(或未提交读)指读取正在被另一事务修改但尚未提交的行。

可用两个查询复现:

查询1------准备事务但不结束:

sql 复制代码
CREATE TABLE dbo.demo (col1 INT, col2 VARCHAR(255))
GO
-- 正常提交的行
BEGIN TRANSACTION;
INSERT INTO dbo.demo(col1,col2) VALUES (99,'Normal transaction');
COMMIT TRANSACTION;

-- 卡在打开事务中的行
BEGIN TRANSACTION;
INSERT INTO dbo.demo(col1,col2) VALUES (42,'Dirty read');
-- 此处不执行 COMMIT 或 ROLLBACK

查询2------使用未提交读读取包括打开事务中的行:

sql 复制代码
SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
SELECT * FROM dbo.demo

返回:

复制代码
col1 | col2
-----+-------------
99   | Normal transaction
42   | Dirty read

清理:

sql 复制代码
COMMIT TRANSACTION;
DROP TABLE dbo.demo;
GO

63.3 未提交读(Read Uncommitted)

sql 复制代码
SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED

最宽松级别,不放置任何锁,可读取未提交的行,可能出现脏读。

63.4 可重复读(Repeatable Read)

sql 复制代码
SET TRANSACTION ISOLATION LEVEL REPEATABLE READ

比 READ COMMITTED 严格,共享锁会保持到事务结束,而非语句结束,防止不可重复读,但可能出现幻读。注意性能影响和死锁风险。

63.5 快照(Snapshot)

sql 复制代码
SET TRANSACTION ISOLATION LEVEL SNAPSHOT

事务读取的是事务开始时已提交的数据版本,不放置共享锁,可防止脏读、不可重复读和幻读。需先开启数据库选项:

sql 复制代码
ALTER DATABASE YourDB SET ALLOW_SNAPSHOT_ISOLATION ON;

63.6 可串行化(Serializable)

sql 复制代码
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE

最严格级别,对读取的键范围加范围锁,防止其他事务插入匹配范围的新行,避免脏读、不可重复读和幻读,但并发度最低,易引发阻塞和死锁,仅必要时使用。

相关推荐
2301_781571426 小时前
Golang格式化输出占位符都有什么_Golang fmt占位符教程【通俗】
jvm·数据库·python
养肥胖虎6 小时前
RAG学习笔记(3):区分数据库检索与RAG的使用场景
数据库·ai·rag
_ku_ku_6 小时前
数据库系统原理 · 数据库应用开发 · 自学总结
数据库
Upsy-Daisy7 小时前
AI Agent 项目学习笔记(二):Spring AI 与 ChatClient 主链路解析
人工智能·笔记·学习
No8g攻城狮7 小时前
【人大金仓】wsl2+ubuntu22.04安装人大金仓数据库V9
java·数据库·spring boot·非关系型数据库
山峰哥7 小时前
SQL慢查询调优实战:从全表扫描到索引覆盖的完整复盘
前端·数据库·sql·性能优化
代码中介商8 小时前
Redis入门:5大数据类型全解析
数据库·redis·缓存
渣渣盟8 小时前
数据库设计范式详解(纯小白版)
数据库·oracle·软考·数据库工程师
杨浦老苏8 小时前
AI原生笔记应用Tolaria
笔记·ai·markdown·obsidian
中屹指纹浏览器9 小时前
浏览器网络栈隔离技术研究:TCP/IP底层指纹生成与规避原理
经验分享·笔记