标准SQL定义了4个隔离级别

Read uncommitted  未提交读

Read committed    已提交读  

Repeatable read    可重复读

Serializable      可序列化

基本语法

SET TRANSACTION ISOLATION LEVEL
{ READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SNAPSHOT | SERIALIZABLE };

1、READ UNCOMMITTED

未提交读是最低的事务隔离级别,允许读取其他事务已经修改但未提交的数据行。在该隔离级别下,针对数据资源的读操作将不会申请共享锁,也不影响其他事物对该数据资源请求排他或独占锁,直接读取数据。在该事物隔离级别下,有可能读取到其他事物中修改但未提交的数据,因此这种读取也被称作脏读

未提交读与NOLOCK语句具有相同的效果。

CREATE TABLE Test
(
Id BIGINT PRIMARY KEY,
Name NVARCHAR(20) DEFAULT NULL
)

往表中新增两条数据

INSERT INTO Test VALUES(0,'陈楚生'),(1,'白百何')

在事物A中更新Id为0的数据,但不提交

BEGIN TRAN
--在事物中修改Test中Id为0的数据,但不提交
UPDATE Test SET Name='范玮琪' WHERE Id=0

在事物B中使用未提交读级别查询Id为0的数据

--使用未提交读级别将会读取到其他事物中未提交的修改,产生脏读
SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
BEGIN TRAN
SELECT * FROM Test WHERE Id=0
COMMIT

结果可见在事物B中读取到了事物A中未提交的修改。

2、READ COMMITTED

已提交读是大部分关系型数据库的默认事物隔离级别,在该级别下,只能读取到其他事物已提交的修改。当事务读取数据时,数据库引擎将放置共享锁以防止其他事务修改该数据,读取完成则释放共享锁,此时其他事物可以对数据继续进行修改。

假如在一个事物A中,有两个相同的查询语句S1、S2,在已提交读级别下,当执行S1语句时,读操作将会申请共享锁,此时另一个事物B将智能对S1数据资源进行读操作,而不能进行写操作。待事物A中S1语句执行完毕之后,数据资源申请的共享锁被释放,此时假如B事物对S1语句的数据资源进行修改(共享锁已被释放,此时可以被修改),然后事物A继续执行S2,此时虽然S1语句和S2语句一样,但是由于在这两个语句之间,事物B对资源做了修改操作,就有可能导致S1、S2语句得到不一样的结果,这种现象叫不可重复读

在SQL SERVER 2005以上版本中,如果设置READ_COMMITTED_SNAPSHOT为ON,则在快照隔离级别下读操作不需要申请获得共享锁,也不影响其他事物对数据申请排他或独占锁,而且仍然可以得到和SERIALIZABLE与READ COMMITTED隔离级别类似的一致性;如果目前版本与预期的版本不一致,读操作可以从TEMPDB中获取预期的版本。

在事物A中修改Id为0的数据,但不提交

BEGIN TRAN
--在事物中修改Test中Id为0的数据,但不提交
UPDATE Test SET Name='范玮琪' WHERE Id=0

在事物B中使用已提交读隔离级别读取Id为0的数据

SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
BEGIN TRAN
SELECT * FROM Test WHERE Id=0
COMMIT

结果

3、3.REPEATABLE READ

在可重复读隔离级别下,对第一次的查询数据资源请求共享锁,并保留到事务结束,因此在整个事物过程中,重复查询相同记录时,不受其他事物的影响。但由于共享锁知道事务结束才会被释放,因此如果事务持续太久,将有可能影响到其他事物对这些数据的写入操作。【共享锁】

在可重复读的隔离级别下查询Id为0的数据,但不提交

SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
BEGIN TRAN
--查询结果为Id为1的数据,针对该数据数据库引擎将会放置共享锁
--因此在其他事物中对Id为0的数据做修改或者新增新数据,都不受影响
SELECT * FROM Test WHERE Id>0

在另外一个事物中对Id为1的数据执行更新操作,此时因为Id为1数据上的共享锁跟随所在的事务释放,而事务未提交或回滚,因此该更新操作将不能执行。

BEGIN TRAN
UPDATE Test SET Name='范玮琪' WHERE Id=1
COMMIT

结果

4、SERIALIZABLE

在可重复读隔离级别下,数据库引擎将会锁定符合查询条件的数据资源,确保这些资源在事务周期内的一致性,但不能锁定查询结果之外的行。例如有两个事务A、B

假如A的事物隔离级别为可重复读,并且在A中有两个相同的查询S1、S2,当执行S1语句时,数据库引擎将会在S1的数据资源上设置共享锁,

因此其他事务中对该部分资源将智能查看而不能修改,此时事务B对资源表进行新增操作,并且新增的数据符合S1和S2的查询条件,然后事务A继续执行S2语句,

此时S2结果将会与S1结果不同,这种现象称之为幻读。可序列化隔离级别与HOLDLOCK具有相同效果

在可序列化隔离级别下,将会对整个范围的资源添加区间锁,整个区间范围内的数据都将被锁定,直到事务被提交或回滚。

在可序列化级别下,执行一个查询Id>0的操作,但不提交事务

SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;
BEGIN TRAN
--查询结果为Id大于1的数据,都将被锁定,不能新增,修改,删除。
SELECT * FROM Test WHERE Id>0

在另外一个事物中执行新增Id=3的操作

BEGIN TRAN
INSERT INTO Test VALUES(3,'马天宇')
COMMIT

在另外一个事物中执行删除Id=2的操作

BEGIN TRAN
DELETE FROM Test WHERE Id=2
COMMIT

在另外一个事物中执行更新Id=2的操作

BEGIN TRAN
UPDATE Test SET Name='陈楚生' WHERE Id=2
COMMIT

结果都是

可见在可序列化隔离级别下满足条件范围的资源都将被锁定

SQL事物隔离级别的更多相关文章

  1. SQL 事务隔离级别

    转载来源:https://www.cnblogs.com/chenmh/p/3998614.html 标签: SQL SEERVER/MSSQL SERVER/SQL/事务隔离级别选项/设置数据库事务 ...

  2. 30分钟全面解析-SQL事务+隔离级别+阻塞+死锁

    以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化.  本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...

  3. Sql Server隔离级别(2)

    Sql Server2005之后,引入了一个新的隔离级别Snapshot(Read Committed Snapshot Isolation (RCSI))和(Snapshot Isolation ( ...

  4. spring事物传播机制 事物隔离级别

    Spring事务类型详解: PROPAGATION_REQUIRED--支持当前事务,如果当前没有事务,就新建一个事务.这是最常见的选择. PROPAGATION_SUPPORTS--支持当前事务,如 ...

  5. 图解 sql 事务隔离级别

    sql 事务隔离级别有四种分种为: 一 Read Uncpommitted(未提交读) 二 Read Committed(提交读) 三 Repeated Read(可重复读) 四 Serializab ...

  6. 【概念原理】四种SQL事务隔离级别和事务ACID特性

    摘要: SQL事务隔离级别和事务的ACID特性 事务是一组读写操作,并且具有只有所有操作都成功才算成功的特性.   事务隔离级别 SQL事务隔离级别由弱到强分别是:READ_UNCOMMITTED.R ...

  7. (4.12)全面解析-SQL事务+隔离级别+阻塞+死锁

    30分钟全面解析-SQL事务+隔离级别+阻塞+死锁 转自:https://blog.csdn.net/slowlifes/article/details/52752735 2016年10月07日 23 ...

  8. (分享别人的一篇好文章,来自jackson0714)30分钟全面解析-SQL事务+隔离级别+阻塞+死锁()

    30分钟全面解析-SQL事务+隔离级别+阻塞+死锁 阅读目录 概述: 一.事务 二.锁 三.阻塞 四.隔离级别 五.死锁 以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQ ...

  9. Spring事物隔离级别及事物传播行为@Transactional实现

    阅读本篇文章前,请先阅读如下文章: 四种事物隔离级别详解 先看下@Transactional可以配制那些参数及以其所代表的意义. isolation 枚举org.springframework.tra ...

随机推荐

  1. machine leanring 笔记 octave命令笔记

    来源于coursea 的公开课 A*B 一般意义的矩阵相乘 A.*B矩阵各位相乘 A.^2 A矩阵的每个数平方 1./A  对A矩阵的各位取倒 .表示对每一项都如此操作 log (A) exp(A) ...

  2. 关于CMFCPropertyGridFontProperty的赋值问题

    CMFCPropertyGridFontProperty是派生于CMFCPropertyGridProperty类的用于字体设置的类.它可以设置字体的名称.大小.粗细等各项参数.但是类并不提供用于初始 ...

  3. hdu4044 GeoDefense

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4044 题意:一个树上的塔防游戏.给你n个结点的树,你要在树结点上建塔防御,在第 i 个结点上有 ki ...

  4. LVS简单实现NAT&DR模型

    LVS:Linux Virtual Server  一个由章文嵩博士发起的自由软件项目,它的官方站点是www.linuxvirtualserver.org. 现在LVS已经是Linux标准内核的一部分 ...

  5. python第十八天-----Django基础

    1.路由系统 a.普通路由 url(r'^index$', views.index), b.正则路由 url(r'^index/(\d*)', views.index), url(r'^manage/ ...

  6. Android多线程编程之AsyncTask

    进程?线程? 进程是并发执行的程序在执行过程中分配和管理资源的基本单位,是一个动态的概念.每个进程都有自己的地址空间(进程空间).进程空间的大小与处理机位数有关.进程至少有5种基本状态:初始态,执行态 ...

  7. 在css嵌套中的html的table里的字左右不对齐

    [现象]AAAA与天数的数字左右不居中 <table border=1 align="center"> <tr> <td width="20 ...

  8. 一次疏忽导致的bug

    NBB_PUT_SHORT 这个宏是按char* 类型算指针的实际工作中,没有注意这一点,输入指针类型 强转为了 SHORT* 导致 填充的内容错误 这是第一次在工作中遇到 指针类型相关的问题值得记录 ...

  9. java中运算符的优先级

    所谓优先级,就是在表达式中的运算顺序.Java 中常用的运算符的优先级如下表所示: 级别为 1 的优先级最高,级别 11 的优先级最低.譬如,x = 7 + 3 * 2  得到的结果是 13 &quo ...

  10. tomcat项目的部署

    当我们把web项目做好了以后,一般要进行部署,我一般采用两种方式来部署.一种是直接启动tomcat的startup.bat,一种是将tomcat做成服务. 1.第一种方法较为简单,先复制一份tomca ...