oracle数据库连接业务系统,而有些sql语句的执行严重影响了oracle的性能,就如同mysql的慢查询一样,mysql可以开启慢查询日志定位这些造成数据库性能下降的语句,而oracle同样可以做到,而且有过之而无不及。
下面举例说明
首先用root用户登陆核心应用系统,su - oracle
执行命令 topas
可以查看到如下信息:
解释三个地方
1.Idle%:是cpu的空闲率
2.PID:进程唯一标示符
3.CPU%:该进程所占用的cpu的百分比
从上述信息可以定位进程为1454604的进程占用资源比较高,查询该进程的sql语句情况。
登陆核心系统oracle数据库,执行以下语句
select c.spid,a.p1,a.p1raw,a.p2,a.event,b.sql_text,b.SQL_FULLTEXT,b.SQL_ID
from v$session a,v$sql b,v$process c
where a.wait_class<>'Idle' and a.sql_id=b.sql_id and a.PADDR=c.addr
order by event;
情况如下图所示: