您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關(guān)postgresql數(shù)據(jù)庫(kù)中出現(xiàn)鎖表如何解決,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。
查詢是否鎖表了
select oid from pg_class where relname='可能鎖表了的表'
select pid from pg_locks where relation='上面查出的oid'
如果查詢到了結(jié)果,表示該表被鎖 則需要釋放鎖定
select pg_cancel_backend(上面查到的pid)
補(bǔ)充:PostgreSQL 解決鎖表、死鎖問(wèn)題
1.-- 查詢ACTIVITY的狀態(tài)等信息
SELECT T .PID, T.STATE, T.QUERY, T.WAIT_EVENT_TYPE, T.WAIT_EVENT, T.QUERY_START FROM PG_STAT_ACTIVITY T WHERE T.DATNAME = '數(shù)據(jù)庫(kù)用戶名';
上面查詢結(jié)果中:pid就是ACTIVITY的唯一標(biāo)識(shí),state就是活動(dòng)狀態(tài),query就是正在執(zhí)行的sql語(yǔ)句,query——start就是開(kāi)始執(zhí)行的時(shí)間。
2.-- 查詢死鎖的ACTIVITY
SELECT T .PID, T.STATE, T.QUERY, T.WAIT_EVENT_TYPE, T.WAIT_EVENT, T.QUERY_START FROM PG_STAT_ACTIVITY T WHERE T.DATNAME = '數(shù)據(jù)庫(kù)用戶名' AND T.WAIT_EVENT_TYPE = 'Lock';
3.將第二條查詢語(yǔ)句的pid字段的數(shù)字值記錄下來(lái),執(zhí)行下面的查詢語(yǔ)句可以解鎖:
-- 通過(guò)pid解鎖對(duì)應(yīng)的ACTIVITY
select PG_CANCEL_BACKEND('6984');
上面的查詢語(yǔ)句,執(zhí)行了pg_cancel_backend()函數(shù),該函數(shù)是取消后臺(tái)操作,回滾未提交事物的用途。
4.解決idle in transaction
select pg_terminate_backend ('21967')
以上就是postgresql數(shù)據(jù)庫(kù)中出現(xiàn)鎖表如何解決,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。