Oracle数据库数据恢复、性能优化

找回密码
注册
搜索
热搜: 活动 交友 discuz
发新帖

0

积分

1

好友

9

主题
1#
发表于 2013-3-27 14:14:36 | 查看: 3854| 回复: 4
1. 在v$sql_plan视图的CPU_COST上显示1432975482
2. 看这个sql语句的执行计划如下:
SQL> r
  1  select t.*
  2    from payment t, casualty_policy t2
  3   where t.insurance_confirm_code is null
  4     and t.insurance_no = t2.insurance_no
  5     and t.create_date > to_date('2012-10-01', 'yyyy-MM-dd')
  6     and t.direction = '-1'
  7     and t.scan_status != '1'
  8   order by t.id desc
  9*

155 rows selected.


Execution Plan
----------------------------------------------------------
Plan hash value: 356225284

---------------------------------------------------------------------------------------------
| Id  | Operation           | Name                  | Rows  | Bytes | Cost (%CPU)| Time     |
---------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT    |                       |   938 |   146K|  9915   (1)| 00:01:59 |
|   1 |  SORT ORDER BY      |                       |   938 |   146K|  9915   (1)| 00:01:59 |
|   2 |   NESTED LOOPS      |                       |   938 |   146K|  9914   (1)| 00:01:59 |
|*  3 |    TABLE ACCESS FULL| PAYMENT               |   966 |   133K|  7981   (2)| 00:01:36 |
|*  4 |    INDEX RANGE SCAN | CASUALTY_POLICY_INDX3 |     1 |    19 |     2   (0)| 00:00:01 |
---------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

   3 - filter("T"."INSURANCE_CONFIRM_CODE" IS NULL AND "T"."CREATE_DATE">TO_DATE('
              2012-10-01 00:00:00', 'syyyy-mm-dd hh24:mi:ss') AND "T"."DIRECTION"=(-1) AND
              "T"."SCAN_STATUS"<>'1')
   4 - access("T"."INSURANCE_NO"="T2"."INSURANCE_NO")


Statistics
----------------------------------------------------------
          0  recursive calls
          0  db block gets
      35981  consistent gets
          0  physical reads
          0  redo size
      12351  bytes sent via SQL*Net to client
        602  bytes received via SQL*Net from client
         12  SQL*Net roundtrips to/from client
          1  sorts (memory)
          0  sorts (disk)
        155  rows processed

当前读+一致性读=35981,除于155 大约等于232,这在rac系统上算很耗时了吧
2#
发表于 2013-3-27 14:34:59
本帖最后由 黑豆 于 2013-3-27 14:43 编辑

索引中的数据

QQ截图20130327143502.png (42.12 KB, 下载次数: 424)

QQ截图20130327143502.png

回复 只看该作者 道具 举报

3#
发表于 2013-3-27 14:35:57
本帖最后由 黑豆 于 2013-3-27 14:37 编辑

dba_indexes

QQ截图20130327143502.png (42.12 KB, 下载次数: 434)

QQ截图20130327143502.png

回复 只看该作者 道具 举报

4#
发表于 2013-3-27 21:11:28
只是一点逻辑读 而已 , 应当是 体现在TABLE ACCESS FULL| PAYMENT

逻辑读不是物理读

如果你要研究SQL 优化 ,给出如下信息:

请使用 sql health check 脚本 分析该SQL 然后上传HTML
http://www.oracledatabase12g.com ... h-check-script.html

回复 只看该作者 道具 举报

5#
发表于 2013-3-27 23:17:10
本帖最后由 黑豆 于 2013-4-3 09:06 编辑

刘老师,您好。有一份db time在一个小时内达到2000分钟的AWR报告,附件上传,并有根据您提供的脚本跑了其中一个耗时的sql。请您根据AWR报告帮忙分析一下查找问题的思路

目前我的思路是这样的,如有理解不对的请指出:
1. 由于top 5事件中前两个是latch: library cache和latch: shared pool两个latch的等待事件,那么系统的sql应该存在大量的硬解析和软解析,或者sql没有绑定变量,或者sql的绑定变量不合适导致没起作用。
2. 再查看Soft Parse 达到97.90%,每秒的Hard parses只有0.25,这样来看似乎并不会对系统引起latch争用的问题。
3. 继续看Execute to Parse %,在一百次的解析中不用重新解析的次数是60.42,有点高
4. 再查看Time Model Statistics中耗时最高的为sql execute elapsed time,达到61,770.33s,为db time的53.9%,那么就可以肯定了确实是sql引起的系统负载过高。
5. 然后查看SQL ordered by Elapsed Time块中的第二行,Elap per Exec (s) 每次执行耗时669.16s的sql text,但是目前这个sql的版本很多,附件为其中一个版本的sql通过脚本运行后的性能分析html结果。
6. 如果在系统前台页面上的数据检索,使用者都会或多或少的筛选几个选项来选择出自己想要的最小的数据范围,对于这种的要求肯定避免不了在后台通过拼接sql来达到要求,所以导致sql版本比较多。

20130402195819.rar

11.84 KB, 阅读权限: 10, 下载次数: 2

030802-rac-aix.rar

53.84 KB, 阅读权限: 10, 下载次数: 2

回复 只看该作者 道具 举报

您需要登录后才可以回帖 登录 | 注册

QQ|手机版|Archiver|Oracle数据库数据恢复、性能优化

GMT+8, 2025-1-14 13:13 , Processed in 0.050013 second(s), 23 queries .

Powered by Discuz! X2.5

© 2001-2012 Comsenz Inc.

回顶部
TEL/電話+86 13764045638
Email service@parnassusdata.com
QQ 47079569