亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

SQL Server中的事務與鎖

2024-08-31 00:55:44
字體:
來源:轉載
供稿:網友
SQL Server中的事務與鎖了解事務和鎖

事務:保持邏輯數據一致性與可恢復性,必不可少的利器。

鎖:多用戶訪問同一數據庫資源時,對訪問的先后次序權限管理的一種機制,沒有他事務或許將會一塌糊涂,不能保證數據的安全正確讀寫。

死鎖:是數據庫性能的重量級殺手之一,而死鎖卻是不同事務之間搶占數據資源造成的。

不懂的聽上去,挺神奇的,懂的感覺我在扯淡,下面帶你好好領略下他們的風采,嗅査下他們的狂騷。。

先說事務--概念,分類

用華仔無間道中的一句來給你詮釋下:去不了終點,回到原點。

舉例說明:

在一個事務中,你寫啦2條sql語句,一條是修改訂單表狀態,一條是修改庫存表庫存-1 。 如果在修改訂單表狀態的時候出錯,事務能夠回滾,數據將恢復到沒修改之前的數據狀態,下面的修改庫存也就不執行,這樣確保你關系邏輯的一致,安全。。

事務就是這個樣子,倔脾氣,要么全部執行,要么全部不執行,回到原數據狀態。

書面解釋:事務具有原子性,一致性,隔離性,持久性。

  • 原子性:事務必須是一個自動工作的單元,要么全部執行,要么全部不執行。
  • 一致性:事務結束的時候,所有的內部數據都是正確的。
  • 隔離性:并發多個事務時,各個事務不干涉內部數據,處理的都是另外一個事務處理之前或之后的數據。
  • 持久性:事務提交之后,數據是永久性的,不可再回滾。

然而在SQL Server中事務被分為3類常見的事務:

  • 自動提交事務:是SQL Server默認的一種事務模式,每條Sql語句都被看成一個事務進行處理,你應該沒有見過,一條Update 修改2個字段的語句,只修該了1個字段而另外一個字段沒有修改。。
  • 顯式事務:T-sql標明,由Begin Transaction開啟事務開始,由Commit Transaction 提交事務、Rollback Transaction 回滾事務結束。
  • 隱式事務:使用Set IMPLICIT_TRANSACTIONS ON 將將隱式事務模式打開,不用Begin Transaction開啟事務,當一個事務結束,這個模式會自動啟用下一個事務,只用Commit Transaction 提交事務、Rollback Transaction 回滾事務即可。
顯式事務的應用

常用語句就四個。

  • Begin Transaction:標記事務開始。
  • Commit Transaction:事務已經成功執行,數據已經處理妥當。
  • Rollback Transaction:數據處理過程中出錯,回滾到沒有處理之前的數據狀態,或回滾到事務內部的保存點。
  • Save Transaction:事務內部設置的保存點,就是事務可以不全部回滾,只回滾到這里,保證事務內部不出錯的前提下。

上面的都是心法,下面的給你來個招式,要看仔細啦。

 1 ---開啟事務 2 begin tran 3 --錯誤撲捉機制,看好啦,這里也有的。并且可以嵌套。 4 begin try   5    --語句正確 6    insert into lives (Eat,Play,Numb) values ('豬肉','足球',1) 7    --Numb為int類型,出錯 8    insert into lives (Eat,Play,Numb) values ('豬肉','足球','abc') 9    --語句正確10    insert into lives (Eat,Play,Numb) values ('狗肉','籃球',2)11 end try12 begin catch13    select Error_number() as ErrorNumber,  --錯誤代碼14           Error_severity() as ErrorSeverity,  --錯誤嚴重級別,級別小于10 try catch 捕獲不到15           Error_state() as ErrorState ,  --錯誤狀態碼16           Error_PRocedure() as ErrorProcedure , --出現錯誤的存儲過程或觸發器的名稱。17           Error_line() as ErrorLine,  --發生錯誤的行號18           Error_message() as ErrorMessage  --錯誤的具體信息19    if(@@trancount>0) --全局變量@@trancount,事務開啟此值+1,他用來判斷是有開啟事務20       rollback tran  ---由于出錯,這里回滾到開始,第一條語句也沒有插入成功。21 end catch22 if(@@trancount>0)23 commit tran  --如果成功Lives表中,將會有3條數據。24 25 --表本身為空表,ID ,Numb為int 類型,其它為nvarchar類型26 select * from lives

---開啟事務begin tran--錯誤撲捉機制,看好啦,這里也有的。并且可以嵌套。begin try       --語句正確   insert into lives (Eat,Play,Numb) values ('豬肉','足球',1)       --加入保存點   save tran pigOneIn   --Numb為int類型,出錯   insert into lives (Eat,Play,Numb) values ('豬肉','足球',2)   --語句正確   insert into lives (Eat,Play,Numb) values ('狗肉','籃球',3)end trybegin catch   select Error_number() as ErrorNumber,  --錯誤代碼          Error_severity() as ErrorSeverity,  --錯誤嚴重級別,級別小于10 try catch 捕獲不到          Error_state() as ErrorState ,  --錯誤狀態碼          Error_Procedure() as ErrorProcedure , --出現錯誤的存儲過程或觸發器的名稱。          Error_line() as ErrorLine,  --發生錯誤的行號          Error_message() as ErrorMessage  --錯誤的具體信息   if(@@trancount>0) --全局變量@@trancount,事務開啟此值+1,他用來判斷是有開啟事務      rollback tran   ---由于出錯,這里回滾事務到原點,第一條語句也沒有插入成功。end catchif(@@trancount>0)rollback tran pigOneIn --如果成功Lives表中,將會有3條數據。--表本身為空表,ID ,Numb為int 類型,其它為nvarchar類型select * from lives

使用set xact_abort

設置 xact_abort on/off , 指定是否回滾當前事務,為on時如果當前sql出錯,回滾整個事務,為off時如果sql出錯回滾當前sql語句,其它語句照常運行讀寫數據庫。

需要注意的時:xact_abort只對運行時出現的錯誤有用,如果sql語句存在編譯時錯誤,那么他就失靈啦。

delete lives  --清空數據set xact_abort offbegin tran     --語句正確   insert into lives (Eat,Play,Numb) values ('豬肉','足球',1)      --Numb為int類型,出錯,如果1234..那個大數據換成'132dsaf' xact_abort將失效   insert into lives (Eat,Play,Numb) values ('豬肉','足球',12345646879783213)   --語句正確   insert into lives (Eat,Play,Numb) values ('狗肉','籃球',3)commit transelect * from lives

為on時,結果集為空,因為運行是數據過大溢出出錯,回滾整個事務。

事務把死鎖給整出來啦

跟著做:打開兩個查詢窗口,把下面的語句,分別放入2個查詢窗口,在5秒內運行2個事務模塊。

begin tran   update lives set play='羽毛球'  waitfor delay '0:0:5'    update dbo.Earth set Animal='老虎' commit tran
begin tran   update Earth set Animal='老虎'   waitfor  delay '0:0:5' --等待5秒執行下面的語句  update lives set play='羽毛球'commit transelect * from livesselect * from Earth

為什么呢,下面我們看看鎖,什么是鎖。

并發事務成敗皆歸于鎖——鎖定

在多用戶都用事務同時訪問同一個數據資源的情況下,就會造成以下幾種數據錯誤。

  • 更新丟失:多個用戶同時對一個數據資源進行更新,必定會產生被覆蓋的數據,造成數據讀寫異常。
  • 不可重復讀:如果一個用戶在一個事務中多次讀取一條數據,而另外一個用戶則同時更新啦這條數據,造成第一個用戶多次讀取數據不一致。
  • 臟讀:第一個事務讀取第二個事務正在更新的數據表,如果第二個事務還沒有更新完成,那么第一個事務讀取的數據將是一半為更新過的,一半還沒更新過的數據,這樣的數據毫無意義。
  • 幻讀:第一個事務讀取一個結果集后,第二個事務,對這個結果集經行增刪操作,然而第一個事務中再次對這個結果集進行查詢時,數據發現丟失或新增。

然而鎖定,就是為解決這些問題所生的,他的存在使得一個事務對他自己的數據塊進行操作的時候,而另外一個事務則不能插足這些數據塊。這就是所謂的鎖定。

鎖定從數據庫系統的角度大致可以分為6種:

  • 共享鎖(S):還可以叫他讀鎖??梢圆l讀取數據,但不能修改數據。也就是說當數據資源上存在共享鎖的時候,所有的事務都不能對這個資源進行修改,直到數據讀取完成,共享鎖釋放。
  • 排它鎖(X):還可以叫他獨占鎖、寫鎖。就是如果你對數據資源進行增刪改操作時,不允許其它任何事務操作這塊資源,直到排它鎖被釋放,防止同時對同一資源進行多重操作。
  • 更新鎖(U):防止出現死鎖的鎖模式,兩個事務對一個數據資源進行先讀取在修改的情況下,使用共享鎖和排它鎖有時會出現死鎖現象,而使用更新鎖則可以避免死鎖的出現。資源的更新鎖一次只能分配給一個事務,如果需要對資源進行修改,更新鎖會變成排他鎖,否則變為共享鎖。
  • 意向鎖:SQL Server需要在層次結構中的底層資源上(如行,列)獲取共享鎖,排它鎖,更新鎖。例如表級放置了意向共享鎖,就表示事務要對表的頁或行上使用共享鎖。在表的某一行上上放置意向鎖,可以防止其它事務獲取其它不兼容的的鎖。意向鎖可以提高性能,因為數據引擎不需要檢測資源的每一列每一行,就能判斷是否可以獲取到該資源的兼容鎖。意向鎖包括三種類型:意向共享鎖(IS),意向排他鎖(IX),意向排他共享鎖(SIX)。
  • 架構鎖:防止修改表結構時,并發訪問的鎖。
  • 大容量更新鎖:允許多個線程將大容量數據并發的插入到同一個表中,在加載的同時,不允許其它進程訪問該表。

這些鎖之間的相互兼容性,也就是,是否可以同時存在。

現有的授權模式

請求的模式

IS

S

U

IX

SIX

X

意向共享 (IS)

共享 (S)

更新 (U)

意向排他 (IX)

意向排他共享 (SIX)

排他 (X)

鎖兼容性具體參見:http://msdn.microsoft.com/zh-cn/library/ms186396.aspx

鎖粒度和層次結構參見:http://msdn.microsoft.com/zh-cn/library/ms189849(v=sql.105).aspx

死鎖

什么是死鎖,為什么會產生死鎖。我用 “事務把死鎖給整出來啦” 標題下的兩個事務產生的死鎖來解釋應該會更加生動形象點。

例子是這樣的:

第一個事務(稱為A):先更新lives表 --->>停頓5秒---->>更新earth表

第二個事務(稱為B):先更新earth表--->>停頓5秒---->>更新lives表

先執行事務A----5秒之內---執行事務B,出現死鎖現象。

過程是這樣子的:

  1. A更新lives表,請求lives的排他鎖,成功。
  2. B更新earth表,請求earth的排他鎖,成功。
  3. 5秒過后
  4. A更新earth,請求earth的排它鎖,由于B占用著earth的排它鎖,等待。
  5. B更新lives,請求lives的排它鎖,由于A占用著lives的排它鎖,等待。

這樣相互等待對方釋放資源,造成資源讀寫擁擠堵塞的情況,就被稱為死鎖現象,也叫做阻塞。而為什么會產生,上例就列舉出來啦。

然而數據庫并沒有出現無限等待的情況,是因為數據庫搜索引擎會定期檢測這種狀況,一旦發現有情況,立馬選擇一個事務作為犧牲品。犧牲的事務,將會回滾數據。有點像兩個人在過獨木橋,兩個無腦的人都走在啦獨木橋中間,如果不落水,必定要有一個人給退回來。這種相互等待的過程,是一種耗時耗資源的現象,所以能避則避。

哪個人會被退回來,作為犧牲品,這個我們是可以控制的??刂普Z法:

set deadlock_priority  <級別>

死鎖處理的優先級別為 low<normal<high,不指定的情況下默認為normal,犧牲品為隨機。如果指定,犧牲品為級別低的。

還可以使用數字來處理標識級別:-10到-5為low,-5為normal,-5到10為high。

減少死鎖的發生,提高數據庫性能

死鎖耗時耗資源,然而在大型數據庫中,高并發帶來的死鎖是不可避免的,所以我們只能讓其變的更少。

  1. 按照同一順序訪問數據庫資源,上述例子就不會發生死鎖啦
  2. 保持是事務的簡短,盡量不要讓一個事務處理過于復雜的讀寫操作。事務過于復雜,占用資源會增多,處理時間增長,容易與其它事務沖突,提升死鎖概率。
  3. 盡量不要在事務中要求用戶響應,比如修改新增數據之后在完成整個事務的提交,這樣延長事務占用資源的時間,也會提升死鎖概率。
  4. 盡量減少數據庫的并發量。
  5. 盡可能使用分區表,分區視圖,把數據放置在不同的磁盤和文件組中,分散訪問保存在不同分區的數據,減少因為表中放置鎖而造成的其它事務長時間等待。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
麻豆国产精品va在线观看不卡| 国产v综合ⅴ日韩v欧美大片| 国产精品久久久久久av| 亚洲精品国产综合久久| 欧洲美女免费图片一区| 欧美视频免费在线观看| 97碰碰碰免费色视频| 日韩在线视频网| 欧美片一区二区三区| 日韩电影在线观看免费| 激情亚洲一区二区三区四区| 2023亚洲男人天堂| 日韩在线精品视频| 九九久久精品一区| 亚洲爱爱爱爱爱| 国产99久久精品一区二区永久免费| 日韩高清电影免费观看完整| 日韩美女视频免费在线观看| 亚洲直播在线一区| 亚洲国产精品成人va在线观看| 欧美精品激情blacked18| 欧美激情亚洲另类| 日韩精品视频在线免费观看| 情事1991在线| 久久久av网站| 国产一区玩具在线观看| 日韩精品免费在线播放| 亚洲人成欧美中文字幕| 亚洲精品成人网| 亚洲精品免费网站| 国产亚洲精品美女久久久| 午夜精品99久久免费| 欧美乱大交xxxxx另类电影| 久久精品电影网站| 久久天天躁狠狠躁老女人| 久久在线免费观看视频| 国产亚洲美女精品久久久| 欧美激情伊人电影| 91免费高清视频| 成人免费观看49www在线观看| 国产原创欧美精品| 午夜精品久久久久久久久久久久| 奇米成人av国产一区二区三区| 91美女福利视频高清| 久久久av电影| 日韩中文字幕视频| 26uuu日韩精品一区二区| 亚洲性视频网站| 欧美精品久久久久久久久久| 亚洲精品久久7777777| 国产一区二区精品丝袜| 国产ts人妖一区二区三区| 欧美在线视频导航| 国产成人短视频| 久久精品2019中文字幕| 久久久久久久久久久av| 国产精品影片在线观看| 国产日韩精品综合网站| 7777精品久久久久久| 欧美精品video| 欧美亚洲第一页| 中日韩午夜理伦电影免费| 亚洲男人天堂2024| 国产91网红主播在线观看| 久久精品美女视频网站| 午夜精品一区二区三区av| 欧美激情一二三| 国产精品久久综合av爱欲tv| 免费99精品国产自在在线| 亚洲欧美成人一区二区在线电影| 日韩精品极品在线观看播放免费视频| 亚洲女人天堂色在线7777| 亚洲天堂av在线免费观看| 欧美国产在线视频| 日韩精品中文字幕在线| 68精品国产免费久久久久久婷婷| 日韩免费av片在线观看| 国产亚洲欧美另类中文| 91久久精品一区| 午夜精品久久久久久久白皮肤| 欧美精品电影免费在线观看| 精品国产自在精品国产浪潮| 日韩精品在线观看网站| 日韩国产高清视频在线| 中文字幕日韩在线观看| 69影院欧美专区视频| 亚洲午夜国产成人av电影男同| 欧美尺度大的性做爰视频| 97成人在线视频| 国产成人激情小视频| 性色av一区二区三区在线观看| 亚洲free性xxxx护士白浆| 国产精品第10页| 久久国产精品久久久久久| 欧美多人爱爱视频网站| 精品视频在线播放| 国产亚洲欧美日韩精品| 精品无人区太爽高潮在线播放| 欧美裸身视频免费观看| 亚洲福利在线观看| 国产精品视频免费在线| 亚洲黄色成人网| 亚洲成人激情图| 亚洲大胆美女视频| 欧美黑人狂野猛交老妇| 欧美最猛性xxxx| 最近中文字幕mv在线一区二区三区四区| 精品中文字幕在线2019| 国产精品99久久99久久久二8| 亚洲视频在线观看视频| 国产成人福利网站| 久久天堂电影网| 国产不卡视频在线| 亚洲色图五月天| 国产成人精品久久| 91高清视频免费| 欧美精品电影在线| 69影院欧美专区视频| 欧美性xxxx极品hd欧美风情| 成人国产精品久久久久久亚洲| 91精品久久久久| 日韩av免费在线观看| 精品国产一区二区三区久久久| 97人洗澡人人免费公开视频碰碰碰| 中文亚洲视频在线| 色婷婷亚洲mv天堂mv在影片| 欧美精品久久久久a| 欧美激情成人在线视频| 成人97在线观看视频| 中文字幕亚洲在线| 国产精品igao视频| 中文字幕欧美国内| 2019中文在线观看| 精品国产区一区二区三区在线观看| 欧美成人合集magnet| 欧美黑人性生活视频| 91色在线视频| 亚洲直播在线一区| 久久天天躁狠狠躁夜夜躁2014| 国产欧美婷婷中文| 欧美久久精品午夜青青大伊人| 91久久精品国产91久久| 日韩成人小视频| 亚洲视频国产视频| 91理论片午午论夜理片久久| 久久精品中文字幕一区| 国产日韩欧美日韩大片| 国产精品美腿一区在线看| 欧美大片欧美激情性色a∨久久| 久久免费精品视频| 欧美成人全部免费| 亚洲欧美日韩精品久久奇米色影视| 欧美巨猛xxxx猛交黑人97人| 国产成人av在线播放| 国产一区二区三区在线| 久久久精品影院| 国a精品视频大全| www.国产精品一二区| 精品久久久av| 亚洲精品99久久久久中文字幕| 国产精品视频一区二区高潮| 日韩精品在线观看网站| 欧亚精品中文字幕| 亚洲free性xxxx护士白浆|