溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

postgresql數(shù)據(jù)庫(kù)中出現(xiàn)鎖表如何解決

發(fā)布時(shí)間:2020-12-31 15:41:51 來(lái)源:億速云 閱讀:2323 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

本篇文章給大家分享的是有關(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ù)用戶名';

postgresql數(shù)據(jù)庫(kù)中出現(xiàn)鎖表如何解決

上面查詢結(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è)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI