RadarURL
Skip to content
조회 수 648 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

 

 

Lock확인 및 Lock해제는 sys, system 계정으로 sqlplus 및 toad 접속하여 아래의 명령을 실행한다.

 

1. Lock 걸린 테이블 및 세션 확인

 

1) SID, 시리얼번호, 테이블명 확인

 

SELECT
    a.sid, a.serial#, a.username, a.process, b.object_name, 
    DECODE(c.lmode,2,'RS',3,'RX',4,'S',5,'SRX',8,'X','NO') "TABLE LOCK", 
    DECODE(a.command,2,'INSERT',3,'SELECT',6,'UPDATE',7,'DELETE',12,'DROP TABLE',26,'LOCK TABLE','UNknown') "SQL", 
    DECODE(a.lockwait, NULL,'NO wait','Wait') "STATUS" 
FROM
    v$session a, dba_objects b, v$lock c 
WHERE 
    a.sid=c.sid and b.object_id=c.id1 
AND c.type='TM';


2) SID, 테이블명 확인

SELECT 
    vo.session_id, do.object_name, do.owner, do.object_type,do.owner, 
    vo.xidusn, vo.locked_mode 
FROM 
    v$locked_object vo , dba_objects do 
WHERE 
    vo.object_id = do.object_id;

 

 

3) 테이블명, Lock 상태 확인

SELECT  
    T1.object_name, 
    DECODE(locked_mode, 2, 'ROW SHARE', 3, 'ROW EXCLUSIVE',  4, 'SHARE', 5, 'SHARE ROW EXCLUSIVE', 6, 'EXCLUSIVE', 'UNKNOWN') lock_mode 
FROM  
    dba_objects T1, v$locked_object T2 
WHERE 
    T1.object_id = T2.object_id;

 

 

4) LOCK 상태와 세션 문자열 확인
 (출력정렬  스크립트)

set linesize 132 pagesize 66
break on Kill on username on terminal
column Kill heading 'Kill String' format a13
column res heading 'Resource Type' format 999
column id1 format 9999990
column id2 format 9999990
column lmode heading 'Lock Held' format a20
column request heading 'Lock Requested' format a20
column serial# format 99999
column username  format a10  heading "Username"
column terminal heading Term format a6
column tab format a35 heading "Table Name"
column owner format a9
column Address format a18
SELECT 
    nvl(S.USERNAME,'Internal') username,
    nvl(S.TERMINAL,'None') terminal,
    L.SID||','||S.SERIAL# Kill,
    U1.NAME||'.'||substr(T1.NAME,1,20) tab,
    decode(L.LMODE,1,'No Lock',
            2,'Row Share',
            3,'Row Exclusive',
            4,'Share',
            5,'Share Row Exclusive',
            6,'Exclusive',null) lmode,
    decode(L.REQUEST,1,'No Lock',
            2,'Row Share',
            3,'Row Exclusive',
            4,'Share',
            5,'Share Row Exclusive',
            6,'Exclusive',null) request
FROM
    V$LOCK L,
    V$SESSION S,
    SYS.USER$ U1,
    SYS.OBJ$ T1
WHERE        
    L.SID = S.SID
AND T1.OBJ# = decode(L.ID2,0,L.ID1,L.ID2)
AND U1.USER# = T1.OWNER#
AND S.TYPE != 'BACKGROUND'
ORDER BY 1,2,5

 

 

 

2. Lock 걸린 테이블 세션 제거

 

usage) ALTER SYSTEM KILL SESSION 'session ID, 시리얼번호'


ex) ALTER SYSTEM KILL SESSION '189,26359'

 

 

3. PROCESS ID를 찾아내어 OS에서 제거
  (Lock 걸린 테이블의 세션 제거가 안될 경우)
  
1) PID 검색

 

SELECT 
    substr(s.username,1,11) "ORACLE USER", p.pid "PROCESS ID", 
    s.sid "SESSION ID", s.serial#, osuser "OS USER", 
    p.spid "PROC SPID",s.process "SESS SPID", s.lockwait "LOCK WAIT" 
FROM 
    v$process p, v$session s, v$access a 
WHERE 
    a.sid=s.sid
AND p.addr=s.paddr
AND s.username != 'SYS';

 

 

2) 리눅스에서 PID 제거 
위 sql 검색결과에서 Lock걸린 v$session.process 번호를 아래의 pid에 넣으면 된다.


$kill -9 pid

 

 

 

 

출처 : http://blog.naver.com/tchobd/30066708333

TAG •
?

  1. No Image 28Mar
    by JAESOO
    2016/03/28 by JAESOO
    Views 648 

    [Oracle] Lock 확인 및 Lock 해제

  2. No Image 24Oct
    by JAESOO
    2014/10/24 by JAESOO
    Views 1331 

    오라클 실행 (sqlplus /nolog)

  3. No Image 24Oct
    by JAESOO
    2014/10/24 by JAESOO
    Views 1076 

    오라클(Oracle) 테이블 스페이스 자동 증가

  4. No Image 24Oct
    by JAESOO
    2014/10/24 by JAESOO
    Views 1261 

    오라클 테이블스페이스 용량 늘리기

  5. No Image 24Oct
    by JAESOO
    2014/10/24 by JAESOO
    Views 1626 

    오라클(ORACLE) 테이블 스페이스 용량 늘리기

  6. No Image 04Aug
    by JAESOO
    2014/08/04 by JAESOO
    Views 1951 

    오라클 테이블에서 컬럼의 데이터 타입 수정 방법

  7. No Image 04Aug
    by JAESOO
    2014/08/04 by JAESOO
    Views 831 

    Oracle Data Type의 종류?

  8. No Image 22Jul
    by JAESOO
    2014/07/22 by JAESOO
    Views 1418 

    Single DB Admin Level 1 - Oracle Log 확인

  9. No Image 22Jul
    by JAESOO
    2014/07/22 by JAESOO
    Views 10247 

    오라클 스케쥴러 사용법 및 개념 정리

  10. No Image 24Jun
    by JAESOO
    2014/06/24 by JAESOO
    Views 8404 

    Silent mode Oracle 11gr2 설치 - CentOS 5.5 x64, cloudn VM에서

  11. No Image 19Apr
    by JaeSoo
    2014/04/19 by JaeSoo
    Views 1871 

    오라클 업데이트, 딜리트 쿼리 (oracle update, delete query)

  12. No Image 01Apr
    by JaeSoo
    2014/04/01 by JaeSoo
    Views 2955 

    오라클(Oracle) 제품종류 및 라이센스 정책 (10g 기준)

  13. No Image 25Mar
    by JaeSoo
    2014/03/25 by JaeSoo
    Views 966 

    오라클 db 백업-(exp) 명령

  14. No Image 25Mar
    by JaeSoo
    2014/03/25 by JaeSoo
    Views 1188 

    Oracle 리눅스에서 백업하는 방법

  15. No Image 08Feb
    by JaeSoo
    2014/02/08 by JaeSoo
    Views 1922 

    Database 모든 테이블 컬럼 정보 받아오는 쿼리 [오라클]

  16. No Image 08Feb
    by JaeSoo
    2014/02/08 by JaeSoo
    Views 2602 

    테이블 정의서 (table layout) 출력하기 [오라클]

  17. No Image 20Jul
    by JaeSoo
    2012/07/20 by JaeSoo
    Views 7443 

    오라클(Oracle) 테이블스페이스(TableSpace) 정리

  18. No Image 10Oct
    by JaeSoo
    2007/10/10 by JaeSoo
    Views 11438 

    Oracle 10g XE JDBC 연결하기

Board Pagination Prev 1 Next
/ 1

PageViews   Today : 1619 Yesterday : 3868 Total : 22785220  /  Counter Status   Today : 916 Yesterday : 2110 Total : 1384182

Edited by JAESOO

sketchbook5, 스케치북5

sketchbook5, 스케치북5

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

설치 취소