今天数据库访问忽然很慢,经过top命令发现oracle的cpu使用率很高。同事建议查询一下看看是什么语句致使的oracle运行变慢。因而从网上查了一下,能够根据pid查询出正在执行的查询语句,发现是一个大表的字段没有建立索引致使全表扫描。具体操做步骤以下:sql
su - oracle
sqlplus /nolog
connect sysdba
SELECT sql_text FROM v$sqltext a WHERE (a.hash_value, a.address) IN (SELECT DECODE(sql_hash_value, 0, prev_hash_value, sql_hash_value), DECODE(sql_hash_value, 0, prev_sql_addr, sql_address) FROM v$session b WHERE b.paddr = (SELECT addr FROM v$process c WHERE c.spid = '21340')) ORDER BY piece ASC;