728x90
반응형
728x170
■ 잠금 프로세스를 조회하는 방법을 보여준다.
▶ 예제 코드 (SQL)
SELECT
BLOCKED_LOCKS.PID AS BLOCKED_PID
,BLOCKED_ACTIVITY.USENAME AS BLOCKED_USER
,BLOCKING_LOCKS.PID AS BLOCKING_PID
,BLOCKING_ACTIVITY.USENAME AS BLOCKING_USER
,BLOCKED_ACTIVITY.QUERY AS BLOCKED_STATEMENT
,BLOCKING_ACTIVITY.QUERY AS CURRENT_STATEMENT_IN_BLOCKING_PROCESS
FROM PG_CATALOG.PG_LOCKS BLOCKED_LOCKS
JOIN PG_CATALOG.PG_STAT_ACTIVITY BLOCKED_ACTIVITY ON BLOCKED_ACTIVITY.PID = BLOCKED_LOCKS.PID
JOIN PG_CATALOG.PG_LOCKS BLOCKING_LOCKS ON BLOCKING_LOCKS.LOCKTYPE = BLOCKED_LOCKS.LOCKTYPE
AND BLOCKING_LOCKS.DATABASE IS NOT DISTINCT FROM BLOCKED_LOCKS.DATABASE
AND BLOCKING_LOCKS.RELATION IS NOT DISTINCT FROM BLOCKED_LOCKS.RELATION
AND BLOCKING_LOCKS.PAGE IS NOT DISTINCT FROM BLOCKED_LOCKS.PAGE
AND BLOCKING_LOCKS.TUPLE IS NOT DISTINCT FROM BLOCKED_LOCKS.TUPLE
AND BLOCKING_LOCKS.VIRTUALXID IS NOT DISTINCT FROM BLOCKED_LOCKS.VIRTUALXID
AND BLOCKING_LOCKS.TRANSACTIONID IS NOT DISTINCT FROM BLOCKED_LOCKS.TRANSACTIONID
AND BLOCKING_LOCKS.CLASSID IS NOT DISTINCT FROM BLOCKED_LOCKS.CLASSID
AND BLOCKING_LOCKS.OBJID IS NOT DISTINCT FROM BLOCKED_LOCKS.OBJID
AND BLOCKING_LOCKS.OBJSUBID IS NOT DISTINCT FROM BLOCKED_LOCKS.OBJSUBID
AND BLOCKING_LOCKS.PID != BLOCKED_LOCKS.PID
JOIN PG_CATALOG.PG_STAT_ACTIVITY BLOCKING_ACTIVITY ON BLOCKING_ACTIVITY.PID = BLOCKING_LOCKS.PID
WHERE NOT BLOCKED_LOCKS.GRANTED;
728x90
반응형
그리드형(광고전용)
'Database > PostgreSQL' 카테고리의 다른 글
[DATABASE/POSTGRESQL] 컬럼 추가하기 (0) | 2019.09.29 |
---|---|
[DATABASE/POSTGRESQL] 재귀적으로 잠금 프로세스 조회하기 (0) | 2019.09.25 |
[DATABASE/POSTGRESQL] 잠금 프로세스 조회하기 (0) | 2019.09.25 |
[DATABASE/POSTGRESQL] 잠금 프로세스 조회하기 (0) | 2019.09.25 |
[DATABASE/POSTGRESQL] 잠금 프로세스 조회하기 (0) | 2019.09.25 |
[DATABASE/POSTGRESQL] 모든 잠금 조회하기 (0) | 2019.09.25 |
[DATABASE/POSTGRESQL] 미사용 인덱스 조회하기 (0) | 2019.09.25 |
[DATABASE/POSTGRESQL] 테이블 크기 조회하기 (0) | 2019.09.25 |
[DATABASE/POSTGRESQL] 데이터베이스 크기 조회하기 (0) | 2019.09.25 |
[DATABASE/POSTGRESQL] CACHE에 있는 인덱스 조회하기 (0) | 2019.09.25 |
댓글을 달아 주세요