oracle数据库使用过程中,可能会出现死锁等情况,需要通过sql查询哪些语句导致死锁,及解决死锁问题,处理方式如下:
注意:以下sql可能存在执行权限问题,可能需要使用sysadmin等高权限的账号进行执行
一、查询进行中的进程SQL
如果服务器上对应有多个表空间或用户,可以在where条件中指定USERAME
SELECT b.sid,
b.serial#,
b.username,
b.machine,
b.paddr,
b.event,
to_char(b.sql_exec_start,'yyyy-mm-dd hh24:mi:ss') sql_exec_start,
--sa.sql_text,
--dbms_lob.substr(sa.sql_fulltext, 3000),
sa.version_count,
sa.plan_hash_value,
sa.sql_id,
sa.sql_fulltext,
sa.executions, --执行次数
round(sa.cpu_time / 1000000, 2) total_cpu_time_SECOND, --总CPU执行时间 单位秒
round(sa.elapsed_time / 1000000, 2) total_elapsed_time_SECOND, --总执行时间 单位秒
round(sa.elapsed_time / 1000000 / decode(sa.executions,0,1,sa.executions), 2) avg_elapsed_time_SECOND, --平均执行时间 单位秒
round(sa.buffer_gets,2) buffer_gets, --读缓存区次数
sa.physical_read_requests, --IO请求数
sa.disk_reads disk_reads, --磁盘读次数
round(sa.physical_read_bytes/1024/1024,2) physical_read_MB, --物理读 单位M
--round(sa.direct_reads,2) direct_reads,
round(sa.physical_write_bytes/1024/1024,2) physical_write_MB, --物理写 单位M
--round(sa.direct_writes,2) direct_writes,
sa.fetches,
round(sa.rows_processed/decode(sa.executions,0,1,sa.executions),2) avg_rows_processed, --平均每次处理的行数
sa.sorts,
sa.optimizer_cost,
'alter system kill session ' || '''' || b.sid || ',' ||b.SERIAL# ||',@' || b.inst_id ||''';' kill_command
FROM gv$session b, gv$sqlarea sa
WHERE b.sql_hash_value = hash_value
and b.sql_address = address
and b.inst_id = sa.inst_id
--and b.sql_exec_start >= sysdate -300/24/60/60;
--and round(sa.elapsed_time / 1000000 / decode(sa.executions,0,1,sa.executions), 2) > 30
order by round(sa.elapsed_time / 1000000 / decode(sa.executions,0,1,sa.executions), 2) desc;
二、执行相关KILL_COMMAND
可以先提前看下SQL_FULLTEXT里的内容是什么,目前正在执行的sql均包含在其中
三、数据库服务器上杀死进程
部分sql可能使用kill_command无法删除,或者要花很长时间,此时我们可以考虑直接去服务器上进行处理
1、查询相关线程id(其中sid可用前面查询出来的sid)
--数据库 session id
select sid from v$session
--linux操作系统进程 或者 windows线程 (线程要根据session id 查询)
select spid from v$process t where t.addr in (select paddr from v$session where sid = '上面的sid传到这里' );
2、windows服务器杀死进程
访问数据库服务器,启动ProcessExplorer软件并双击oracle.exe
根据前面查出来的sid,即该软件中的TID,选中对应的进程,并点击“kill”
之后点击“确定”,等待几秒后即可杀死该进程