校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Postgresql - 查看鎖表信息的實現

Postgresql - 查看鎖表信息的實現

熱門標簽:海豐有多少商家沒有地圖標注 地圖標注和圖片名稱的區別 辦公外呼電話系統 漯河外呼電話系統 合肥公司外呼系統運營商 打電話智能電銷機器人授權 重慶自動外呼系統定制 美容工作室地圖標注 外呼調研系統

查看表鎖信息,是DBA常用的腳本之一。

實驗環境:

CentOS 7

PG 10.4

先通過A窗口執行

mytest=# begin;
BEGIN
mytest=# update t1 set col1 = 'a' where id =1 ;
UPDATE 1
mytest=#

打開B窗口執行

mytest=# begin;
BEGIN
mytest=# update t1 set col1 = 'b' where id =2;
UPDATE 1
mytest=# update t1 set col1 = 'b' where id =1;

等待了

說明只鎖住了行,對于更新其他行沒有影響。

再打開一個窗口查看信息

SELECT
a.datname,
locktype,
virtualtransaction,
transactionid,
nspname,
relname,
mode,
granted,
cast(date_trunc('second',query_start) AS timestamp) AS query_start
FROM
pg_locks
LEFT OUTER JOIN pg_class ON (pg_locks.relation = pg_class.oid)
LEFT OUTER JOIN pg_namespace ON (pg_namespace.oid = pg_class.relnamespace),
pg_stat_activity a
WHERE NOT pg_locks.pid = pg_backend_pid()
AND pg_locks.pid=a.pid;
datname | locktype | virtualtransaction | transactionid | nspname | relname | mode | granted | query_start
---------+---------------+--------------------+---------------+---------+---------+------------------+---------+---------------------
mytest | relation | 7/332 | | public | t1 | RowExclusiveLock | t | 2018-06-28 06:29:58
mytest | virtualxid | 7/332 | | | | ExclusiveLock | t | 2018-06-28 06:29:58
mytest | relation | 6/42 | | public | t1 | RowExclusiveLock | t | 2018-06-28 06:29:35
mytest | virtualxid | 6/42 | | | | ExclusiveLock | t | 2018-06-28 06:29:35
mytest | transactionid | 7/332 | 712 | | | ExclusiveLock | t | 2018-06-28 06:29:58
mytest | transactionid | 6/42 | 711 | | | ExclusiveLock | t | 2018-06-28 06:29:35
mytest | transactionid | 7/332 | 711 | | | ShareLock | f | 2018-06-28 06:29:58
mytest | tuple | 7/332 | | public | t1 | ExclusiveLock | t | 2018-06-28 06:29:58
(8 rows)

補充:如何查看PostgreSQL正在執行的SQL以及鎖信息

查看當前正在運行的SQL

SELECT 
procpid, 
start, 
now() - start AS lap, 
current_query 
FROM 
(SELECT 
backendid, 
pg_stat_get_backend_pid(S.backendid) AS procpid, 
pg_stat_get_backend_activity_start(S.backendid) AS start, 
pg_stat_get_backend_activity(S.backendid) AS current_query 
FROM 
(SELECT pg_stat_get_backend_idset() AS backendid) AS S 
) AS S 
WHERE 
current_query > 'IDLE>' 
ORDER BY 
lap DESC; 
procpid:進程id 
start:進程開始時間 
lap:經過時間 
current_query:執行中的sql 
怎樣停止正在執行的sql 
SELECT pg_cancel_backend(進程id); 
或者用系統函數 
kill -9 進程id;

查看數據庫目前是否有鎖

-- 查看當前事務鎖等待、持鎖信息的SQL
with  
t_wait as  
(  
 select a.mode,a.locktype,a.database,a.relation,a.page,a.tuple,a.classid,a.granted,  
 a.objid,a.objsubid,a.pid,a.virtualtransaction,a.virtualxid,a.transactionid,a.fastpath,  
 b.state,b.query,b.xact_start,b.query_start,b.usename,b.datname,b.client_addr,b.client_port,b.application_name  
  from pg_locks a,pg_stat_activity b where a.pid=b.pid and not a.granted  
),  
t_run as  
(  
 select a.mode,a.locktype,a.database,a.relation,a.page,a.tuple,a.classid,a.granted,  
 a.objid,a.objsubid,a.pid,a.virtualtransaction,a.virtualxid,a.transactionid,a.fastpath,  
 b.state,b.query,b.xact_start,b.query_start,b.usename,b.datname,b.client_addr,b.client_port,b.application_name  
  from pg_locks a,pg_stat_activity b where a.pid=b.pid and a.granted  
),  
t_overlap as  
(  
 select r.* from t_wait w join t_run r on  
 (  
  r.locktype is not distinct from w.locktype and  
  r.database is not distinct from w.database and  
  r.relation is not distinct from w.relation and  
  r.page is not distinct from w.page and  
  r.tuple is not distinct from w.tuple and  
  r.virtualxid is not distinct from w.virtualxid and  
  r.transactionid is not distinct from w.transactionid and  
  r.classid is not distinct from w.classid and  
  r.objid is not distinct from w.objid and  
  r.objsubid is not distinct from w.objsubid and  
  r.pid > w.pid  
 )  
),  
t_unionall as  
(  
 select r.* from t_overlap r  
 union all  
 select w.* from t_wait w  
)  
select locktype,datname,relation::regclass,page,tuple,virtualxid,transactionid::text,classid::regclass,objid,objsubid,  
string_agg(  
'Pid: '||case when pid is null then 'NULL' else pid::text end||chr(10)||  
'Lock_Granted: '||case when granted is null then 'NULL' else granted::text end||' , Mode: '||case when mode is null then 'NULL' else mode::text end||' , FastPath: '||case when fastpath is null then 'NULL' else fastpath::text end||' , VirtualTransaction: '||case when virtualtransaction is null then 'NULL' else virtualtransaction::text end||' , Session_State: '||case when state is null then 'NULL' else state::text end||chr(10)||  
'Username: '||case when usename is null then 'NULL' else usename::text end||' , Database: '||case when datname is null then 'NULL' else datname::text end||' , Client_Addr: '||case when client_addr is null then 'NULL' else client_addr::text end||' , Client_Port: '||case when client_port is null then 'NULL' else client_port::text end||' , Application_Name: '||case when application_name is null then 'NULL' else application_name::text end||chr(10)||  
'Xact_Start: '||case when xact_start is null then 'NULL' else xact_start::text end||' , Query_Start: '||case when query_start is null then 'NULL' else query_start::text end||' , Xact_Elapse: '||case when (now()-xact_start) is null then 'NULL' else (now()-xact_start)::text end||' , Query_Elapse: '||case when (now()-query_start) is null then 'NULL' else (now()-query_start)::text end||chr(10)||  
'SQL (Current SQL in Transaction): '||chr(10)|| 
case when query is null then 'NULL' else query::text end,  
chr(10)||'--------'||chr(10)  
order by  
 ( case mode  
  when 'INVALID' then 0  
  when 'AccessShareLock' then 1  
  when 'RowShareLock' then 2  
  when 'RowExclusiveLock' then 3  
  when 'ShareUpdateExclusiveLock' then 4  
  when 'ShareLock' then 5  
  when 'ShareRowExclusiveLock' then 6  
  when 'ExclusiveLock' then 7  
  when 'AccessExclusiveLock' then 8  
  else 0  
 end ) desc,  
 (case when granted then 0 else 1 end) 
) as lock_conflict 
from t_unionall  
group by  
locktype,datname,relation,page,tuple,virtualxid,transactionid::text,classid,objid,objsubid ; 

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • PostgreSQL 實現登錄及修改密碼操作
  • postgresql表死鎖問題的排查方式
  • 基于postgresql數據庫鎖表問題的解決
  • 基于postgresql行級鎖for update測試
  • Postgresql鎖機制詳解(表鎖和行鎖)
  • postgresql查詢鎖表以及解除鎖表操作
  • PostgreSQL中關閉死鎖進程的方法
  • PostgreSQL用戶登錄失敗自動鎖定的處理方案

標簽:珠海 晉城 錦州 烏海 蚌埠 衡陽 株洲 來賓

巨人網絡通訊聲明:本文標題《Postgresql - 查看鎖表信息的實現》,本文關鍵詞  Postgresql,查看,鎖表,信息,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Postgresql - 查看鎖表信息的實現》相關的同類信息!
  • 本頁收集關于Postgresql - 查看鎖表信息的實現的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    亚洲高清在线精品| 免费成人你懂的| 亚洲18女电影在线观看| 一区二区三区国产| 精品一区在线看| 成人91在线观看| 91精品一区二区三区久久久久久 | 国产精品久久久久一区二区三区共 | 欧美色中文字幕| 国产不卡视频在线播放| 色综合色综合色综合色综合色综合| 欧美一级爆毛片| 午夜久久久久久电影| 色嗨嗨av一区二区三区| 久久久久亚洲蜜桃| 美日韩一区二区| 欧美精品久久99久久在免费线| 亚洲黄色在线视频| 欧美日韩免费在线视频| 亚洲国产精品国自产拍av| 精品一区二区免费在线观看| 欧美日韩一二区| 亚洲美腿欧美偷拍| 91久久精品日日躁夜夜躁欧美| 国产欧美精品一区二区三区四区 | 久久久久久免费毛片精品| 五月综合激情网| 欧美日韩三级一区| 天天免费综合色| 欧美高清一级片在线| 香蕉加勒比综合久久| 欧美日韩在线播放一区| 亚洲一级片在线观看| 欧美亚洲日本一区| 日韩精品91亚洲二区在线观看| 欧美乱妇23p| 日韩欧美另类在线| 日本欧美久久久久免费播放网| 欧美精品久久99| 热久久久久久久| 日韩一区二区三区在线视频| 男男视频亚洲欧美| 欧美v日韩v国产v| 国产精品亚洲专一区二区三区| 国产欧美日本一区二区三区| 不卡一区二区在线| 亚洲影院理伦片| 日韩欧美国产成人一区二区| 国产美女精品一区二区三区| 欧美极品少妇xxxxⅹ高跟鞋| 99久久99久久久精品齐齐| 亚洲国产裸拍裸体视频在线观看乱了| 欧美日韩在线不卡| 极品瑜伽女神91| 国产精品色婷婷| 91免费观看视频在线| 丝袜诱惑亚洲看片| 久久久久亚洲蜜桃| 在线视频你懂得一区二区三区| 日韩激情在线观看| 久久久久久**毛片大全| 日本韩国精品一区二区在线观看| 日韩精品欧美精品| 国产欧美一区二区精品婷婷| 91电影在线观看| 久久97超碰国产精品超碰| 日韩美女啊v在线免费观看| 91精品国产91久久久久久最新毛片| 国产综合一区二区| 亚洲v日本v欧美v久久精品| wwwwxxxxx欧美| 欧美日韩一二三区| 成a人片国产精品| 日本麻豆一区二区三区视频| 国产精品麻豆久久久| 日韩欧美一二三四区| 91激情五月电影| 国产精品1区2区3区| 日韩av中文字幕一区二区| 亚洲人精品午夜| 亚洲视频一区在线观看| 日韩女优电影在线观看| 色天天综合色天天久久| 成人综合激情网| 欧美aaaaaa午夜精品| 一区二区三区精品久久久| 中文字幕不卡在线| 精品少妇一区二区三区视频免付费| 欧美在线观看一二区| 成人app下载| 国产不卡视频一区二区三区| 九一久久久久久| 日本中文字幕一区| 亚洲国产视频一区| 亚洲视频在线一区观看| 国产精品视频第一区| 国产亚洲精品精华液| 欧美电影免费观看高清完整版在线| 欧美视频一区在线| 91久久精品一区二区三区| av一二三不卡影片| 成人激情小说乱人伦| 国产91丝袜在线播放| 国产乱妇无码大片在线观看| 日韩av中文在线观看| 日韩av电影天堂| 日精品一区二区三区| 天堂久久一区二区三区| 日韩制服丝袜av| 首页国产丝袜综合| 日日欢夜夜爽一区| 蜜桃av一区二区三区电影| 老司机午夜精品| 老司机精品视频在线| 黑人巨大精品欧美黑白配亚洲| 精品一区二区三区蜜桃| 久久精品理论片| 国产在线日韩欧美| 国产激情一区二区三区四区| 国产超碰在线一区| 成人av电影在线观看| 色综合久久久久久久久| 欧洲精品一区二区| 911精品国产一区二区在线| 欧美日韩aaa| 精品不卡在线视频| 欧美国产一区视频在线观看| 国产精品久久久久影视| 亚洲激情中文1区| 轻轻草成人在线| 久久精品国产色蜜蜜麻豆| 国产一区二三区好的| 国产大片一区二区| av在线不卡电影| 欧美日韩午夜精品| 日韩精品在线看片z| 欧美国产欧美亚州国产日韩mv天天看完整 | 成人av手机在线观看| 九九精品视频在线看| 国产一区高清在线| www.成人在线| 欧美精品久久天天躁| 精品国产91乱码一区二区三区| 欧美高清在线精品一区| 亚洲国产精品欧美一二99| 国产乱人伦精品一区二区在线观看 | 午夜精品福利一区二区三区蜜桃| 日本欧美在线观看| 国产99久久久久久免费看农村| 一本一本大道香蕉久在线精品 | 韩国视频一区二区| 99精品视频在线播放观看| 538在线一区二区精品国产| 日韩精品一区二区三区swag| 日韩毛片一二三区| 精品夜夜嗨av一区二区三区| 久久久综合网站| 国产日韩在线不卡| 婷婷亚洲久悠悠色悠在线播放| 国产精品夜夜嗨| 欧美色老头old∨ideo| 久久午夜免费电影| 亚洲免费资源在线播放| 国产综合成人久久大片91| 欧美影片第一页| 中文av字幕一区| 韩国欧美国产1区| 91久久精品午夜一区二区| 久久精品亚洲精品国产欧美kt∨| 亚洲成人免费av| 91片黄在线观看| 国产欧美一区二区精品忘忧草| 亚欧色一区w666天堂| 91丨九色丨国产丨porny| 久久亚洲一级片| 免费在线观看一区| 欧美日韩在线直播| 亚洲色图在线看| 高清日韩电视剧大全免费| 91精品国产综合久久精品性色| 中文字幕亚洲精品在线观看| 国产一区在线看| 日韩一区二区麻豆国产| 亚洲国产精品麻豆| 在线观看国产一区二区| 国产精品国产自产拍高清av| 国产精品一色哟哟哟| 欧美精品一区二区三区久久久| 日日嗨av一区二区三区四区| 欧美日韩一区在线观看| 亚洲一区二区在线视频| 色一情一乱一乱一91av| 亚洲欧美韩国综合色| 色综合欧美在线视频区| 中文字幕不卡在线播放| 成人深夜在线观看| 中文字幕一区二区5566日韩| 成人永久免费视频| 亚洲欧洲精品一区二区三区不卡| 日韩视频免费观看高清完整版|