系统JAVA,SQL性能优化

查询一个语句的执行次数:

SELECT SQL_ID, SQL_TEXT,FIRST_LOAD_TIME, EXECUTIONS

   FROM V$SQLAREA 

   WHERE SQL_TEXT LIKE '%UPDATE %' and EXECUTIONS > 100000 

    ORDER BY EXECUTIONS 

   

查看当前数据库执行次数最多的SQL,例如,查询执行最频繁的TOP 15的SQL语句:

SELECT SQL_TEXT, EXECUTIONS

  FROM (SELECT SQL_TEXT,

               EXECUTIONS,

               RANK() OVER(ORDER BY EXECUTIONS DESC) EXEC_RANK

          FROM V$SQLAREA)

 WHERE EXEC_RANK <= 15;

下面的句子列出cpu_time占用top 10的sql

select cpu_time,sql_text

from (select sql_text,cpu_time,

rank() over (order by cpu_time desc) exec_rank

from v$sql

      )

where exec_rank <=10;

执行次数最多的top 10

select sql_text,executions

from (select sql_text,executions,

    rank() over

     (order by executions desc) exec_rank

    from v$sql)

where exec_rank <=10;

6. 最浪费内存的前10个语句占所有语句的比例

在没有调整的情况下,大多数系统中10个最常使用的SQL语句的访问量占了整个系统中内存读操作的50%以上。本节测量了最影响性能的代码对整个系统所造成危害的严重性,以百分比表示(小于5%为最佳)。

select sum(pct_bufgets) "Percent" from (select rank() over ( order by buffer_gets desc ) as rank_bufgets,to_char(100 * ratio_to_report(buffer_gets) over (),'999.99') pct_bufgets from v$sqlarea ) where rank_bufgets < 11;

7.调整滥用磁盘读操作的主要语句

我发现在没有作调整的情况下,在绝大多数的系统中,访问量占前25位的语句的磁盘读操作将占用整个系统所有磁盘和/或内存读操作的75%。

select disk_reads, substr(sql_text,1,4000) from v$sqlarea  order by disk_reads desc;

2.查找磁盘读写最多的SQL:

SQL>SELECT * FROM

   (SELECT sql_text,disk_reads "total disk" , executions "total exec",disk_reads/executions "disk/exec" FROM v$sql WHERE executions>0 and is_obsolete='N' ORDER BY 4 desc)

   WHERE ROWNUM<11 ;

http://www.xuebuyuan.com/2210903.html

猜你喜欢

转载自jatter.iteye.com/blog/2327743