`
zuuuzhang
  • 浏览: 28916 次
  • 性别: Icon_minigender_1
  • 来自: 合肥
社区版块
存档分类
最新评论

oracle 查找比较慢的sql和session

 
阅读更多

一、如何找到消耗资源大的Oracle的session及其执行的SQL语句
    HP-UX可以用glance,top、IBM- AIX可以用topas、另外可以使用PS命令查看进程。

    通过这些程序我们可以找到用系统资源特别大的这些进程的进程号,我们就可以通过以下的sql语句发现这个pid正在执行哪个sql,这个sql最好在pl/sql developer,toad等软件中执行, 把<>中的spid换成你的spid就可以了。
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=<spid> 
   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)


二、另一个有用的脚本:查找前十条性能差的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=<sid>;
  Select * from v$sqltext where address=<sql_address>;
执行以上两个语句便可以得到这个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这个参数。


C、db file scattered read,这个参数指的是通过索引来读取,同样可以通过增加db_file_multiblock_read_count这个参数来提高性能。


D、latch free,与栓相关的了,需要专门调节。


E、其他参数可以不特别观注。

 

本文转自http://blog.csdn.net/winterwinner/article/details/4677150,多谢

分享到:
评论

相关推荐

    ORACLE SQL性能优化系列

    当你向ORACLE 提交一个SQL语句,ORACLE会首先在这块内存中查找相同的语句. 这里需要注明的是,ORACLE对两者采取的是一种严格匹配,要达成共享,SQL语句必须 完全相同(包括空格,换行等). 共享的语句必须满足三个...

    oracle 会话 死锁 执行sql 执行job的方法

    //根据用户分组会话 select t.USERNAME,count(*) from v$session t group by t.USERNAME ...select m.SQL_TEXT from v$session t , v$sqlarea m where t.USERNAME ='BUDGET' and t.sql_id = m.SQL_ID // s

    oracle常见的锁查询和处理

    --数据库中的表锁,查找某个表被哪个session锁定 --DML语句产生的锁 --谁锁住了表,引起了谁的等待 --事务,锁,回滚段 --LOCKED_OBJECTS --出错的分布式事务锁 --分布式事务 --Hold进程 --会话式事务锁 --...

    Oracle优化53解

    Oracle语句优化53个... 当你向ORACLE 提交一个SQL语句,ORACLE会首先在这块内存中查找相同的语句。 这里需要注明的是,ORACLE对两者采取的是一种严格匹配,要达成共享,SQL语句必须完全相同(包括空格,换行等)。

    Oracle数据库管理员技术指南

    2.4.1 怎样查找产生锁的 SQL 语句 2.4.2 怎样释放锁 2.4.3 怎样删除用户会话 2.4.4 怎样从数据字典中提取视图创建 命令 2.4.5 怎样从数据字典中提取索引定义 2.5 回顾 第3章 导出和导入技术 3.1 导出/导入...

    Oracle数据库日常维护方案书.docx

    查找前十条性能差的 sql 等待时间最多的 个系统等待事件的获取 检查运行很久的 SQL 检查消耗 CPU 最高的进程 检查碎片程度高的表 检查表空间的 I/O 比例 检查文件系统的 I/O 比例 检查死锁及处理 检查...

    ORACLE重建索引总结

    3、以删除的叶节点数量:指得是数据行的delete操作从逻辑上删除的索引节点 的数量,要记住oracle在删除数据行后,将 “ 死 “ 节点保留在索引中,这样做可以加快sql删除操作的速度,因此oracle删除数据行后可以不必...

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

    SQL&gt; Select * from session_privs;// 查询当前用户所拥有的权限 2. 角色 角色。角色是一组权限的集合,将角色赋给一个用户,这个用户就拥有了这个角色中的所有权限。  系统预定义角色 预定义角色是在数据库安装...

    SQLProgress

    2、数据库的一般功能:SQL语句的导入、导出和打印,查找字符串,调色方案等。 3、数据库的高级功能:DBGrid报表产生(可将DBGrid中的数据变成大于7种文件格式,Field的调整,插入图片,插入项号)、DBGrid的打印,...

    SQL培训第一期

    结构化查询语言(Structured Query Language)简称SQL,是一种关系数据库查询语言,用于存取数据以及查询、更新和管理关系数据库系统。 1.2 语句结构 1.2.1 数据查询语言(DQL) 对数据库进行的信息查询,select。 ...

    Oracle数据库账号被锁定解决方法

    下面记录下查找这个题目的步调。 1. 找到账号被锁按时候 哄骗sqlplus或者sqldeveloper,查询账号被锁定的时候,相干语句如下: –批改当前会话的日期显示格局 alter session set nls_date_format = “”yyyy-MM-dd ...

    SQLProgress1.01.31非最终版

    数据库的一般工具包含,SQL语句的导入、导出和打印,查找字符串,调色方案等。 数据库的高级工具包含,DBGrid报表产生(可将DBGrid中的数据变成7种文件格式,报表中可以进行调整Field,插入图片,插入项号等操作)...

    Oracle用户被锁的原因及解决办法

    SQL&gt; alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss'; Session altered. 2、查看具体的被锁时间 SQL&gt; select username,lock_date from dba_users where username='TEST'; USERNAME LOCK_DATE TEST ...

    orcale常用命令

    列出全部SQL命令和SQL*Plus命令 SQL&gt;help 列出某个特定的命令的信息 SQL&gt;help 命令名 c、显示表结构命令DESCRIBE SQL&gt;DESC 表名 d、SQL*Plus中的编辑命令 显示SQL缓冲区命令 SQL&gt;L 修改SQL命令 首先要将待改正行...

    ORACLE 查询被锁住的对象,并结束其会话的方法

    1、查找出被锁对象的会话ID和序列号 执行如下SQL: -- 查询出被锁对象,并提供 kill 脚本 SELECT S.SID, S.MACHINE, O.OBJECT_NAME, L.ORACLE_USERNAME, L.LOCKED_MODE, S.OSUSESR, 'ALTER SYSTEM KILL SESSION ''...

    SQLProgress 1.01.30A

    数据库的一般工具包含,SQL语句的导入、导出和打印,查找字符串,调色方案等。 数据库的高级工具包含,DBGrid报表产生(可将DBGrid中的数据变成7种文件格式,报表中可以进行调整Field,插入图片,插入项号...

    SQLProgress v1.01.27

     2、数据库的一般功能:SQL语句的导入、导出和打印,查找字符串,调色方案等。  3、数据库的高级功能:DBGrid报表产生(可将DBGrid中的数据变成大于7种文件格式,Field的调整,插入图片,插入项号)、DBGrid的打印...

    SQLProgress1.01.30

    数据库的一般工具包含,SQL语句的导入、导出和打印,查找字符串,调色方案等。 数据库的高级工具包含,DBGrid报表产生(可将DBGrid中的数据变成7种文件格式,报表中可以进行调整Field,插入图片,插入项号等操作)...

Global site tag (gtag.js) - Google Analytics