sql server 隔离级别
解決數(shù)據(jù)庫并發(fā)讀取錯(cuò)亂的途徑之一就是使用事務(wù)進(jìn)行操作,并且設(shè)置相應(yīng)的事務(wù)隔離級(jí)別,現(xiàn)在就解釋一下SQL Server的四種隔離級(jí)別。
?
SQL Server的四種隔離級(jí)別知識(shí)點(diǎn)整理,特別制作了流程圖,方便以后查看!
SET TRANSACTION ISOLATION LEVEL
{
READ UNCOMMITTED
| READ COMMITTED
| REPEATABLE READ
| SERIALIZABLE
}
一、未提交讀READ UNCOMMITTED(臟讀)
意義:包含未提交數(shù)據(jù)的讀。例如,在多用戶環(huán)境下,用戶B更改了某行。用戶A在用戶B提交更改之前讀取已更改的行。如果此時(shí)用戶B再回滾更改,則用戶A便讀取了邏輯上從未存在過的行。(如圖演示)
1)用戶B:
BEGIN TRAN
UPDATE test SET age=25 WHERE name = ‘AA’
2)用戶A:
SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED(此句不寫即默認(rèn)為READ COMMITTED模式)
SELECT * FROM test(此時(shí)將查到AA的age值為25)
3)用戶B:
ROLLBACK(此時(shí)撤消了步驟1的UPDATE操作,則用戶A讀到的錯(cuò)誤數(shù)據(jù)被稱為臟讀)
二、提交讀(READ COMMITTED)
意義:指定在讀取數(shù)據(jù)時(shí)控制共享鎖以避免臟讀。此隔離等級(jí)的主要作用是避免臟讀。
演示:
1)用戶B:
BEGIN TRAN
UPDATE test SET age=25 WHERE name = ‘AA’
2)用戶A:
SET TRANSACTION ISOLATION LEVEL READ COMMITTED
SELECT * FROM test (上句設(shè)置了提交讀模式,則此時(shí)將會(huì)查不到數(shù)據(jù),顯示查詢等待中,直到用戶B進(jìn)行了ROLLBACK或者COMMIT操作后,此語句才會(huì)生效)
三、不一致的分析REPEATABLE READ(重復(fù)讀)
意義:在多用戶環(huán)境下,用戶A開了一個(gè)事務(wù),并且先對(duì)test表的某條記錄做了查詢(select * from test where name = ‘AA’),接著用戶B對(duì)test表做了更新并提交(update test set age=25 where name=’AA’),這時(shí)A再去查test表中的這條記錄,第一次讀到的age值為12,第二次為25,兩次讀到的數(shù)據(jù)不一樣,稱之為重復(fù)讀。(如圖演 示)
?
解決辦法:
在用戶A的事務(wù)運(yùn)行之前,先設(shè)定SQL的隔離等級(jí)為REPEATABLE READ
SQL語句為SET TRANSACTION ISOLATION LEVEL REPEATABLE READ
這樣在上圖第一步中,用戶A查詢完之后,用戶B將無法更新用戶A所查詢到的數(shù)據(jù)集中的任何數(shù)據(jù)(但是可以更新、插入和刪除用戶A查詢到的數(shù)據(jù)集之外的數(shù)據(jù)),直到用戶A事務(wù)結(jié)束才可以進(jìn)行更新,這樣就有效的防止了用戶在同一個(gè)事務(wù)中讀取到不一致的數(shù)據(jù)。
四、幻象(SERIALIZABLE)
意義:在多用戶環(huán)境下,用戶A開啟了一個(gè)事務(wù),并查詢test表中的所有記錄,然后用戶B在自己的事務(wù)中插入(或刪除)了test表中的一條記錄并提交事務(wù),此時(shí)用戶A再去執(zhí)行前面的查詢整張表記錄的操作,結(jié)果會(huì)多出(少了)一條記錄,此操作稱之為幻象。(如圖演示)
?
解決辦法:
在用戶A的事務(wù)運(yùn)行之前,先設(shè)定SQL的隔離等級(jí)為SERIALIZABLE
語句為SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
這樣在用戶A的事務(wù)執(zhí)行過程中,別的用戶都將無法對(duì)任何數(shù)據(jù)進(jìn)行更新、插入和刪除的操作,直到用戶A的事務(wù)回滾或者提交為止。這是四個(gè)隔離級(jí)別中限制最大的級(jí)別。因?yàn)椴l(fā)級(jí)別較低,所以應(yīng)只在必要時(shí)才使用該選項(xiàng)。
轉(zhuǎn)載于:https://www.cnblogs.com/wangzhanjianshe/archive/2011/06/21/2326422.html
總結(jié)
以上是生活随笔為你收集整理的sql server 隔离级别的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【推荐】8款神奇的动态网页布局及其制作方
- 下一篇: Google Map 自定义infowi