一,查询出死锁
SELECT s.username,l.OBJECT_ID,l.SESSION_ID,s.SERIAL#,
l.ORACLE_USERNAME,l.OS_USER_NAME,l.PROCESS
FROM V$LOCKED_OBJECT l,V$SESSION S WHERE l.SESSION_ID=S.SID;
二, 查看死锁的sql语句(返回引起死锁的sql语句)
select sql_text from v$sql where hash_value in
(select sql_hash_value from v$session where sid in
(select session_id from v$locked_object))
三,kill掉这个死锁的进程
alter system kill session ‘sid,serial#’; (其中sid=l.session_id)
四,如果还不能解决的话,查询出死锁的spid
select pro.spid from v$session ses,v$process pro where ses.sid=XX and ses.paddr=pro.addr;
五,进入docker安装的oracle容器中
docker exec -it 容器id /bin/bash
六,删除进程:kill -9 spid