在對(duì)指定表做append操作,其他再做truncate時(shí)候,會(huì)產(chǎn)生鎖表,如下驗(yàn)證步驟,
在惠來(lái)等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專(zhuān)注、極致的服務(wù)理念,為客戶(hù)提供網(wǎng)站建設(shè)、網(wǎng)站制作 網(wǎng)站設(shè)計(jì)制作按需開(kāi)發(fā)網(wǎng)站,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站建設(shè),網(wǎng)絡(luò)營(yíng)銷(xiāo)推廣,外貿(mào)網(wǎng)站建設(shè),惠來(lái)網(wǎng)站建設(shè)費(fèi)用合理。
1、創(chuàng)建測(cè)試表,
create table test_lock(id number, value varchar2(200));
2、執(zhí)行append語(yǔ)句;并且不做提交,insert /*+append*/ into test_lock values(1,1);
3、再次執(zhí)行清表語(yǔ)句,truncate table test_lock;報(bào)鎖表錯(cuò)誤,
4、查看鎖表語(yǔ)句,發(fā)現(xiàn)被鎖表,
select b.object_name, t.*
from v$locked_object t, user_objects b
where t.object_id = b.object_id
一般情況只發(fā)生鎖超時(shí),就是一個(gè)進(jìn)程需要訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)表或者字段的時(shí)候,另外一個(gè)程序正在執(zhí)行帶鎖的訪(fǎng)問(wèn)(比如修改數(shù)據(jù)),那么這個(gè)進(jìn)程就會(huì)等待,當(dāng)?shù)攘撕芫面i還沒(méi)有解除的話(huà)就會(huì)鎖超時(shí),報(bào)告一個(gè)系統(tǒng)錯(cuò)誤,拒絕執(zhí)行相應(yīng)的SQL操作。發(fā)生死鎖的情況比較少,比如一個(gè)進(jìn)程需要訪(fǎng)問(wèn)兩個(gè)資源(數(shù)據(jù)庫(kù)表或者字段),當(dāng)獲取一個(gè)資源的時(shí)候進(jìn)程就對(duì)它執(zhí)行鎖定,然后等待下一個(gè)資源空閑,這時(shí)候如果另外一個(gè)進(jìn)程也需要兩個(gè)資源,而已經(jīng)獲得并鎖定了第二個(gè)資源,那么就會(huì)死鎖,因?yàn)楫?dāng)前進(jìn)程鎖定第一個(gè)資源等待第二個(gè)資源,而另外一個(gè)進(jìn)程鎖定了第二個(gè)資源等待第一個(gè)資源,兩個(gè)進(jìn)程都永遠(yuǎn)得不到滿(mǎn)足。
erp100.com
1.數(shù)據(jù)庫(kù)死鎖的現(xiàn)象程序在執(zhí)行的過(guò)程中,點(diǎn)擊確定或保存按鈕,程序沒(méi)有響應(yīng),也沒(méi)有出現(xiàn)報(bào)錯(cuò)。
2.死鎖的原理當(dāng)對(duì)于數(shù)據(jù)庫(kù)某個(gè)表的某一列做更新或刪除等操作,執(zhí)行完畢后該條語(yǔ)句不提交,另一條對(duì)于這一列數(shù)據(jù)做更新操作的語(yǔ)句在執(zhí)行的...
3.死鎖的定位方法通過(guò)檢查數(shù)據(jù)庫(kù)表,能夠檢查出是哪一條語(yǔ)句被死鎖,產(chǎn)生死鎖的機(jī)器是哪一臺(tái)。 ...
4.死鎖的解決方法 一般情況下,只要將產(chǎn)生死鎖的語(yǔ)句提交就可以了,但是在實(shí)際的執(zhí)行過(guò)程中.
例子?
事務(wù)A 事務(wù)B
時(shí)間點(diǎn)C 請(qǐng)求排他鎖A 請(qǐng)求排他鎖B
時(shí)間點(diǎn)D 請(qǐng)求排他鎖B 請(qǐng)求排他鎖A
這是個(gè)環(huán)路等待的例子吧,結(jié)局是事務(wù)A一致等鎖B的釋放,而事務(wù)B一致等鎖A的釋放
解決的方法 是 重寫(xiě)代碼,2個(gè)鎖一起請(qǐng)求,而不是分開(kāi)請(qǐng)求
DML鎖又可以分為,行鎖、表鎖、死鎖
-行鎖:當(dāng)事務(wù)執(zhí)行數(shù)據(jù)庫(kù)插入、更新、刪除操作時(shí),該事務(wù)自動(dòng)獲得操作表中操作行的排它鎖。
-表級(jí)鎖:當(dāng)事務(wù)獲得行鎖后,此事務(wù)也將自動(dòng)獲得該行的表鎖(共享鎖),以防止其它事務(wù)進(jìn)行DDL語(yǔ)句影響記錄行的更新。事務(wù)也可以在進(jìn)行過(guò)程中獲得共享鎖或排它鎖,只有當(dāng)事務(wù)顯示使用LOCK TABLE語(yǔ)句顯示的定義一個(gè)排它鎖時(shí),事務(wù)才會(huì)獲得表上的排它鎖,也可使用LOCK TABLE顯示的定義一個(gè)表級(jí)的共享鎖(LOCK TABLE具體用法請(qǐng)參考相關(guān)文檔)。
-死鎖:當(dāng)兩個(gè)事務(wù)需要一組有沖突的鎖,而不能將事務(wù)繼續(xù)下去的話(huà),就出現(xiàn)死鎖。
如事務(wù)1在表A行記錄#3中有一排它鎖,并等待事務(wù)2在表A中記錄#4中排它鎖的釋放,而事務(wù)2在表A記錄行#4中有一排它鎖,并等待事務(wù)1在表A中記錄#3中排它鎖的釋放,事務(wù)1與事務(wù)2彼此等待,因此就造成了死鎖。死鎖一般是因拙劣的事務(wù)設(shè)計(jì)而產(chǎn)生。
死鎖只能使用SQL下:alter system kill session "sid,serial#";或者使用相關(guān)操作系統(tǒng)kill進(jìn)程的命令,如UNIX下kill -9 sid,或者使用其它工具殺掉死鎖進(jìn)程。
+DDL鎖又可以分為:排它DDL鎖、共享DDL鎖、分析鎖
-排它DDL鎖:創(chuàng)建、修改、刪除一個(gè)數(shù)據(jù)庫(kù)對(duì)象的DDL語(yǔ)句獲得操作對(duì)象的 排它鎖。如使用alter table語(yǔ)句時(shí),為了維護(hù)數(shù)據(jù)的完成性、一致性、合法性,該事務(wù)獲得一排它DDL鎖。
-共享DDL鎖:需在數(shù)據(jù)庫(kù)對(duì)象之間建立相互依賴(lài)關(guān)系的DDL語(yǔ)句通常需共享獲得DDL鎖。
如創(chuàng)建一個(gè)包,該包中的過(guò)程與函數(shù)引用了不同的數(shù)據(jù)庫(kù)表,當(dāng)編譯此包時(shí),該事務(wù)就獲得了引用表的共享DDL鎖。
-分析鎖:ORACLE使用共享池存儲(chǔ)分析與優(yōu)化過(guò)的SQL語(yǔ)句及PL/SQL程序,使運(yùn)行相同語(yǔ)句的應(yīng)用速度更快。一個(gè)在共享池中緩存的對(duì)象獲得它所引用數(shù)據(jù)庫(kù)對(duì)象的分析鎖。分析鎖是一種獨(dú)特的DDL鎖類(lèi)型,ORACLE使用它追蹤共享池對(duì)象及它所引用數(shù)據(jù)庫(kù)對(duì)象之間的依賴(lài)關(guān)系。當(dāng)一個(gè)事務(wù)修改或刪除了共享池持有分析鎖的數(shù)據(jù)庫(kù)對(duì)象時(shí),ORACLE使共享池中的對(duì)象作廢,下次在引用這條SQL/PLSQL語(yǔ)句時(shí),ORACLE重新分析編譯此語(yǔ)句。
1.可能在Oracle中可以有計(jì)時(shí)器,在頻繁操作數(shù)據(jù)庫(kù),update,insert,delete語(yǔ)句,在jobs中能查看到(如圖)
2.可能在.net程序中使用到timer控件,頻繁的操作數(shù)據(jù)庫(kù)update,insert,delete語(yǔ)句(如圖)
3.可能在.net程序中使用到Thead(線(xiàn)程)頻繁的操作數(shù)據(jù)庫(kù)update,insert,delete語(yǔ)句(這個(gè)條為個(gè)人觀點(diǎn),還未得到證實(shí))
【注釋】:此處更新數(shù)據(jù)量都比較大,比如說(shuō)update的數(shù)據(jù)庫(kù)條數(shù)可能在1000條以上,
導(dǎo)致其他操作在等待(update跟其他操作都是同一張表)
4.可能使用到事務(wù)處理(Tran),沒(méi)有提交事務(wù)(CommintTran)或者沒(méi)有回滾事務(wù)(Rollback)
【注釋】:在SqlServer數(shù)據(jù)庫(kù)里面有一個(gè)隱式事務(wù),關(guān)閉時(shí)候,每次修改插入都需要手動(dòng)提交,不然就會(huì)導(dǎo)致死鎖