鎖表和解鎖

2021-08-14 13:23:21 字數 992 閱讀 8987

前端開發中工作專案融合了hibernate框架,導致在前端頁面對業務表資料進行操作時(

執行資料庫插入、更新、刪除操作),容易導致資料庫鎖表。

這裡直接提供鎖表查詢和解鎖對應的方法:

1.下面的語句用來查詢哪些物件被鎖:

select object_name,machine,s.sid,s.serial#

from v$locked_object l,dba_objects o ,v$session s

where l.object_id = o.object_id and l.session_id=s.sid;

2.下面的語句用來殺死乙個程序:

alter system kill session '24,111'; (其中24,111分別是上面查詢出的sid,serial#)

【注】以上兩步,可以通過oracle的管理控制台來執行。

3.如果利用上面的命令殺死乙個程序後,

程序狀態

被置為"killed",但是鎖定的資源很長時間沒有被釋放,那麼可以在os一級再殺死相應的程序(執行緒),首先執行下面的語句獲得程序(執行緒)號:

select spid, osuser, s.program

from v$session s,v$process p

where s.paddr=p.addr and s.sid=24 (24是上面的sid)

4.在os上殺死這個程序(執行緒):

1)在unix上,用root身份執行命令:

#kill -9 12345(即第3步查詢出的spid)

2)在windows(unix也適用)用orakill殺死執行緒,orakill是oracle提供的乙個可執行命令,語法為:

orakill sid thread

其中:sid:表示要殺死的程序屬於的例項名

thread:是要殺掉的執行緒號,即第3步查詢出的spid。

例:c:>orakill orcl 12345

Oracle鎖表和解鎖

宣告 本文 oracle的鎖表與解鎖select rule s.username,decode l.type,tm table lock tx row lock null lock level,o.owner,o.object name,o.object type,s.sid,s.serial s....

oracle 鎖表查詢 和 解鎖

查詢誰鎖定,誰等待 select rule lpad decode l.xidusn,0,3,0 l.oracle username user name,o.owner,o.object name,o.object type,s.sid,s.serial from v locked object l...

MYSQL鎖表和解鎖語句

對於mysql來說,有三種鎖的級別 頁級 表級 行級 頁級的典型代表引擎為bdb。表級的典型代表引擎為myisam,memory以及很久以前的isam。行級的典型代表引擎為innodb。我們實際應用中用的最多的就是行鎖。行級鎖的優點如下 1 當很多連線分別進行不同的查詢時減小lock狀態。2 如果出...