oracle调优【转】

SELECT a.username,a.machine,a.program,a.sid,a.serial#, a.status,c.piece,c.sql_text
          from v$session a,v$process b, v$sqltext c
      WHERE b.spid='ORCL' AND b.addr=a.paddr AND a.sql_address=c.address(+)
         order BY c.piece  
 
     我们就可以把得到的这个sql分析一下,看一下它的执行计划是否走索引,对其优化避免全表扫描,以减少IO等待,从而加快语句的执行速度。提示:我在做优化sql时,经常碰到使用in的语句,这时我们一定要用exists把它给换掉,因为Oracle在处理In时是按Or的方式做的,即使使用了索引也会很慢。

 

  比如:
  SELECT col1,col2,col3 
        FROM table1 a
  WHERE a.col1 not in (SELECT col1 FROM table2)

  可以换成:  
      SELECT col1,col2,col3 
         FROM table1 a
    WHERE not exists (SELECT 'x' FROM table2 b WHERE a.col1=b.col1)

4、另一个有用的脚本:查找前十条性能差的sql。
  SELECT * FROM (select PARSING_USER_ID,EXECUTIONS,SORTS,
  COMMAND_TYPE,DISK_READS,sql_text FROM v$sqlarea
  order BY disk_reads DESC )where ROWNUM<10 ;
  二、迅速发现Oracle Server的性能问题的成因,我们可以求助于v$session_wait这个视图,看系统的这些session在等什么,使用了多少的IO。以下是我提供的参考脚本:
  脚本说明:查看占io较大的正在运行的session。
  SELECT se.sid,se.serial#,pr.SPID,se.username,se.status,se.terminal,se.program,se.MODULE,se.sql_address,st.event,st.      p1text,si.physical_reads, si.block_changes  FROM v$session se,v$session_wait st, v$sess_io si,v$process pr WHERE st.sid=se.sid AND st. sid=si.sid AND se.PADDR=pr.ADDR AND se.sid>6 AND st. wait_time=0 AND st.event NOT LIKE '%SQL%' 
      ORDER BY physical_reads DESC

  对检索出的结果的几点说明:
  1、我是按每个正在等待的session已经发生的物理读排的序,因为它与实际的IO相关。

  2、你可以看一下这些等待的进程都在忙什么,语句是否合理?
  Select sql_address from v$session where sid=;

  Select * from v$sqltext where address=; 字串7
  执行以上两个语句便可以得到这个session的语句。你也以用alter system kill session 'sid,serial#';把这个session杀掉。

 

  3、应观注一下event这列,这是我们调优的关键一列,下面对常出现的event做以简要的说明:
  a、buffer busy waits,free buffer waits这两个参数所标识是dbwr是否够用的问题,与IO很大相关的,当v$session_wait中的free buffer wait的条目很小或没有的时侯,说明你的系统的dbwr进程决对够用,不用调整;free buffer wait的条目很多,你的系统感觉起来一定很慢,这时说明你的dbwr已经不够用了,它产生的wio已经成为你的数据库性能的瓶颈,这时的解决办法如下:
  a.1增加写进程,同时要调整db_block_lru_latches参数。
  示例:修改或添加如下两个参数
  db_writer_processes=4
  db_block_lru_latches=8

 

  a、2开异步IO,IBM这方面简单得多,hp则麻烦一些,可以与Hp工程师联系。
  b、db file sequential read,指的是顺序读,即全表扫描,这也是我们应该尽量减少的部分,解决方法就是使用索引、sql调优,同时可以增大db_file_multiblock_read_count这个参数。

oracle 可以在 v$sqlarea (v$sqltext)查询到已经和正在运行的sql
可以在v$open_cursor 中查到正open状态的cursor
可以通过 v$session   join  to  v$sql  查到正在running 的session和sql

oracle可以提供给用户查看和诊断的信息远比你所能想象的多,对比oracle来说, mssql简直就是一个黑匣子

posted @ 2008-12-31 11:34  遇到未来的自己  阅读(299)  评论(0编辑  收藏  举报