久久久久无码精品,四川省少妇一级毛片,老老熟妇xxxxhd,人妻无码少妇一区二区

sql server中避免死鎖的方法

時(shí)間:2024-10-28 23:42:22 SQL 我要投稿
  • 相關(guān)推薦

sql server中避免死鎖的方法

  一、死鎖的四個(gè)必要條件

  1、互斥條件(Mutual exclusion):資源不能被共享,只能由一個(gè)進(jìn)程使用。

  2、請(qǐng)求與保持條件(Hold and wait):已經(jīng)得到資源的進(jìn)程可以再次申請(qǐng)新的資源。

  3、非剝奪條件(No pre-emption):已經(jīng)分配的資源不能從相應(yīng)的進(jìn)程中被強(qiáng)制地剝奪。

  4、循環(huán)等待條件(Circular wait):系統(tǒng)中若干進(jìn)程組成環(huán)路,該環(huán)路中每個(gè)進(jìn)程都在等待相鄰進(jìn)程正占用的資源。

  二、 避免死鎖

  1、按同一順序訪問(wèn)對(duì)象

  如果所有并發(fā)事務(wù)按同一順序訪問(wèn)對(duì)象,則發(fā)生死鎖的可能性會(huì)降低。例如,如果兩個(gè)并發(fā)事務(wù)獲得 Supplier 表上的鎖,然后獲得 Part 表上的鎖,則在其中一個(gè)事務(wù)完成之前,另一個(gè)事務(wù)被阻塞在 Supplier 表上。第一個(gè)事務(wù)提交或回滾后,第二個(gè)事務(wù)繼續(xù)進(jìn)行。不發(fā)生死鎖。將存儲(chǔ)過(guò)程用于所有的數(shù)據(jù)修改可以標(biāo)準(zhǔn)化訪問(wèn)對(duì)象的順序。

  2、避免事務(wù)中的用戶交互

  避免編寫(xiě)包含用戶交互的事務(wù),因?yàn)檫\(yùn)行沒(méi)有用戶交互的批處理的速度要遠(yuǎn)遠(yuǎn)快于用戶手動(dòng)響應(yīng)查詢的速度,例如答復(fù)應(yīng)用程序請(qǐng)求參數(shù)的提示。例如,如果事務(wù)正在等待用戶輸入,而用戶去吃午餐了或者甚至回家過(guò)周末了,則用戶將此事務(wù)掛起使之不能完成。這樣將降低系統(tǒng)的吞吐量,因?yàn)槭聞?wù)持有的任何鎖只有在事務(wù)提交或回滾時(shí)才會(huì)釋放。即使不出現(xiàn)死鎖的情況,訪問(wèn)同一資源的其它事務(wù)也會(huì)被阻塞,等待該事務(wù)完成。

  3、保持事務(wù)簡(jiǎn)短并在一個(gè)批處理中

  在同一數(shù)據(jù)庫(kù)中并發(fā)執(zhí)行多個(gè)需要長(zhǎng)時(shí)間運(yùn)行的事務(wù)時(shí)通常發(fā)生死鎖。事務(wù)運(yùn)行時(shí)間越長(zhǎng),其持有排它鎖或更新鎖的時(shí)間也就越長(zhǎng),從而堵塞了其它活動(dòng)并可能導(dǎo)致死鎖。

  保持事務(wù)在一個(gè)批處理中,可以最小化事務(wù)的網(wǎng)絡(luò)通信往返量,減少完成事務(wù)可能的延遲并釋放鎖。

  4、使用低隔離級(jí)別

  確定事務(wù)是否能在更低的隔離級(jí)別上運(yùn)行。執(zhí)行提交讀允許事務(wù)讀取另一個(gè)事務(wù)已讀取(未修改)的數(shù)據(jù),而不必等待第一個(gè)事務(wù)完成。使用較低的隔離級(jí)別(例如提交讀)而不使用較高的隔離級(jí)別(例如可串行讀)可以縮短持有共享鎖的時(shí)間,從而降低了鎖定爭(zhēng)奪。

  5、使用綁定連接

  使用綁定連接使同一應(yīng)用程序所打開(kāi)的兩個(gè)或多個(gè)連接可以相互合作。次級(jí)連接所獲得的任何鎖可以象由主連接獲得的鎖那樣持有,反之亦然,因此不會(huì)相互阻塞

  6、SELECT語(yǔ)句加With(NoLock)提示

  默認(rèn)情況下SELECT語(yǔ)句會(huì)對(duì)查詢到的資源加S鎖(共享鎖),S鎖與X鎖(排他鎖)不兼容;但加上With(NoLock)后,SELECT不對(duì)查詢到的資源加鎖(或者加Sch-S鎖,Sch-S鎖可以與任何鎖兼容);從而可以是這兩條SQL可以并發(fā)地訪問(wèn)同一資源。當(dāng)然,此方法適合解決讀與寫(xiě)并發(fā)死鎖的情況,但加With(NoLock)可能會(huì)導(dǎo)致臟讀。

【sql server中避免死鎖的方法】相關(guān)文章:

Sql Server、Access數(shù)據(jù)排名的實(shí)現(xiàn)方法07-09

如何快速掌握SQL Server中的日志轉(zhuǎn)移08-04

有關(guān)清除SQL Server日志的兩種方法07-20

SQL Server常用數(shù)據(jù)類(lèi)型06-18

如何更改SQL Server默認(rèn)的1433端口05-19

SQL中的單記錄函數(shù)08-12

2016最新J2EE中SQL語(yǔ)句自動(dòng)構(gòu)造方法08-02

SQL中的單記錄函數(shù)盤(pán)點(diǎn)09-09

PL/SQL編程中的經(jīng)驗(yàn)小結(jié)09-21

如何避免幼兒兒童在舞蹈學(xué)習(xí)、培訓(xùn)中受傷的方法08-09