园子里有很不错的介绍SQL Server事务隔离的文章,感觉很多都从概念入手介绍的,对那些初学者来说,看得见摸得 着的理解才深刻,故不再重复,重点在于实例演示上面。
首先解释下事务隔离是干什么的,一个事务的隔离级别控制了它怎么样影响其它事务和被其它事务所影响。
1.READ UNCOMMITTED,会导致脏读(能读取其它事务没有提交的更改)和不可重复读(事务读取的数据被其它事务 所修改,再次读取时不一致)
初始化:
CREATE TABLE TranLevel (k int IDENTITY(1,1), val int) INSERT INTO TranLevel(val) values(1) INSERT INTO TranLevel(val) values(2) INSERT INTO TranLevel(val) values(3)
首先执行Query1,再新建查询立即执行Query2
Query1:
BEGIN TRAN Query1 -- 在事务中修改 UPDATE TranLevel SET val = 9 -- '等待10秒,期间事务2运行' WAITFOR DELAY '00:00:10' -- 不提交修改,回滚事务 ROLLBACK TRAN Query1
Query2:
-- 设置当前会话事务隔离级别为未提交读 SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED BEGIN TRAN Query2 SELECT '事务2开始并发执行,读取到了事务1修改了但没有提交的数据,是脏读' SELECT * FROM Tranlevel SELECT '事务2等待10秒,让事务1执行完' WAITFOR DELAY '00:00:10' SELECT '两次读取的结果不一致,是不可重复读' SELECT * FROM TranLevel COMMIT TRAN Query2
下面就看看Query2执行的结果是怎样的:
结果显而易见,如果将事务隔离级别设置为未提交读,则会造成脏读和不可重复读的问题,在这几个事务隔离级别中 是限制最小的一个,SQL Server分配的资源也最小。
以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索重复
, select
, 事务
, 结果
, 隔离
, 不可重复读
级别
sql事务隔离级别、sql 设置事务隔离级别、sqlserver隔离级别、sql server 快照隔离、sql server 隔离级别,以便于您获取更多的相关知识。