对比前后执行计划,发现问题 - 9i
链接: http://www.dbaroad.me/archives/2008/11/find-sqlplan-differ.html
检查数据库,发现实例2 latch free较高,TOPAS发现操作系统CPU较高
2 latch free 3487375171 PGATE 7
2 buffer busy global CR 3487375171 PGATE 7
检查导致latch free的SQL语句,如下:
((SELECT a.PT_id, b.acct_code,
NVL (c.description, 'EFG') certificate_type,
NVL (d.description, 'ABC') payed_method,
NVL (e.orgniztion, 'EFG') PT_location,
TO_CHAR (pay_date, 'YYYY-MM-DD HH24:MI:SS') PT_time,
a.amount PT_amount, a.operation_type operation_type
FROM PT_75 a,
acct_75 b,
sys_field_desc c,
sys_field_desc d,
(SELECT x.operator_id, NVL (o.party_role_name, 'EFG') orgniztion
FROM sys_operator x, party_roley, party_role_relat z,
party_role o
WHERE x.party_id = y.party_id(+)
AND y.party_role_id = z.party2_role_id(+)
AND z.party1_role_id = o.party_role_id(+)
AND NVL (x.region_id, 0) IN (75, 0)) e
WHERE a.acct_id = b.acct_id
AND a.amount != 0
AND a.staff_id = e.operator_id(+)
AND c.table_name = 'PT'
AND c.column_name = 'CERTIFICATE_TYPE'
AND a.certificate_type = c.VALUE(+)
AND d.table_name = 'PT_PLAN'
AND d.column_name = 'PT_METHOD'
AND a.payed_method = d.VALUE(+)
AND b.acct_code = :1
AND TO_CHAR (a.pay_date, 'yyyymmdd') >= :2
AND TO_CHAR (a.pay_date, 'yyyymmdd') < = :3))
ORDER BY pay_date DESC
查看其执行计划如下:
[Execution Plan Information]
-------------------------------------------------------------------------------------------------
| Operation | PHV/Object Name | Rows | Bytes| Cost |
-------------------------------------------------------------------------------------------------
|00[00]SELECT STATEMENT |---- 3487375171.0 ---| | | 28 |
|01[01]SORT ORDER BY | | 1 | 218 | 28 |
|02[02] FILTER | | | | |
|03[03] NESTED LOOPS | | 1 | 218 | 12 |
|04[04] NESTED LOOPS OUTER | | 1 | 196 | 10 |
|05[05] NESTED LOOPS | | 1 | 138 | 9 |
|06[06] MERGE JOIN CARTESIAN | | 1 | 86 | 4 |
|07[07] TABLE ACCESS BY INDEX ROWID |SYS_FIELD_DESC | 1 | 43 | 2 |
|08[08] INDEX RANGE SCAN |SYS_FIELD_DESC_1 | 1 | | 1 |
|09[07] BUFFER SORT | | 1 | 43 | 2 |
|10[08] TABLE ACCESS FULL |SYS_FIELD_DESC | 1 | 43 | 2 |
|11[06] TABLE ACCESS BY GLOBAL INDEX ROWID |PT_75 | 1 | 52 | 5 |
|12[07] INDEX RANGE SCAN |IDX_PT_75_DAY | 56K| | 1 |
|13[05] VIEW PUSHED PREDICATE | | 10 | 580 | 1 |
|14[06] NESTED LOOPS OUTER | | 1 | 58 | 7 |
|15[07] NESTED LOOPS OUTER | | 1 | 42 | 6 |
|16[08] NESTED LOOPS OUTER | | 1 | 29 | 4 |
|17[09] TABLE ACCESS BY INDEX ROWID |SYS_OPERATOR | 1 | 15 | 2 |
|18[10] INDEX UNIQUE SCAN |PK_SYS_OPERATOR | 1 | | 1 |
|19[09] TABLE ACCESS BY INDEX ROWID |PARTY_ROLE | 1 | 14 | 2 |
|20[10] INDEX RANGE SCAN |IDX_PARTYROLE_PARTY_ | 1 | | 1 |
|21[08] TABLE ACCESS BY INDEX ROWID |PARTY_ROLE_RELAT | 1 | 13 | 2 |
|22[09] INDEX RANGE SCAN |IDX_PARTY2_ROLE_ID | 1 | | 1 |
|23[07] TABLE ACCESS BY INDEX ROWID |PARTY_ROLE | 1 | 16 | 1 |
|24[08] INDEX UNIQUE SCAN |PK_PARTY_ROLE | 1 | | |
|25[04] TABLE ACCESS BY INDEX ROWID |ACCT_75 | 1 | 22 | 2 |
|26[05] INDEX UNIQUE SCAN |PK_ACCT_75 | 1 | | 1 |
-------------------------------------------------------------------
[Predicate Information]
-------------------------------------------------------------------
2 filter::2< =:3
8 access:"D"."TABLE_NAME"='PT_PLAN' AND "D"."COLUMN_NAME"='PT_
METHOD'
10 filter:"C"."TABLE_NAME"='PT' AND "C"."COLUMN_NAME"='CERTIFICATE_T
YPE'
11 filter:"A"."AMOUNT"<>0 AND "A"."CERTIFICATE_TYPE"="C"."VALUE" AND "A".
"PAYED_METHOD"="D"."VALUE"
12 access:TO_CHAR("A"."PAY_DATE",'yyyymmdd')>=:2 AND TO_CHAR("A"."PAY_DAT
E",'yyyymmdd')< =:3
17 filter:NVL("X"."REGION_ID",0)=75 OR NVL("X"."REGION_ID",0)=0
18 access:"A"."STAFF_ID"="X"."OPERATOR_ID"
20 access:"X"."PARTY_ID"="Y"."PARTY_ID"(+)
22 access:"Y"."PARTY_ROLE_ID"="Z"."PARTY2_ROLE_ID"(+)
24 access:"Z"."PARTY1_ROLE_ID"="O"."PARTY_ROLE_ID"(+)
25 filter:"B"."ACCT_CODE"=:1
26 access:"A"."ACCT_ID"="B"."ACCT_ID"
查看其历史执行计划信息:(通过查询 stats$sql_plan_usage)
------------------------------------------- Instance 1 ------------------------------------
INSTANCE_NUMBER SNAP_ID SNAP_TIME HASH_VALUE PLAN_HASH_VALUE COST OPTIMIZER
--------------- ------- ------------------- ---------- --------------- ---------- ----------
1 95945 2008-10-30 09:05:43 3487375171 378545151 28 CHOOSE
1 95944 2008-10-30 08:45:43 3487375171 378545151 28 CHOOSE
1 95940 2008-10-30 08:25:44 3487375171 378545151 28 CHOOSE
1 95939 2008-10-30 08:05:43 3487375171 378545151 28 CHOOSE
1 95938 2008-10-30 07:45:43 3487375171 378545151 28 CHOOSE
1 95937 2008-10-30 07:25:43 3487375171 378545151 28 CHOOSE
1 95936 2008-10-30 07:05:43 3487375171 378545151 28 CHOOSE
1 95935 2008-10-30 06:45:43 3487375171 378545151 28 CHOOSE
1 95934 2008-10-30 06:25:42 3487375171 378545151 28 CHOOSE
1 95923 2008-10-30 06:05:42 3487375171 378545151 28 CHOOSE
1 95922 2008-10-30 05:45:43 3487375171 378545151 28 CHOOSE
1 95921 2008-10-30 05:25:44 3487375171 378545151 28 CHOOSE
1 95920 2008-10-30 05:05:42 3487375171 378545151 28 CHOOSE
1 95919 2008-10-30 04:45:43 3487375171 378545151 28 CHOOSE
1 95918 2008-10-30 04:25:43 3487375171 378545151 28 CHOOSE
1 95917 2008-10-30 04:05:42 3487375171 378545151 28 CHOOSE
1 95916 2008-10-30 03:45:42 3487375171 378545151 28 CHOOSE
1 95915 2008-10-30 03:25:42 3487375171 378545151 28 CHOOSE
1 95914 2008-10-30 03:05:43 3487375171 378545151 28 CHOOSE
1 95903 2008-10-30 02:45:42 3487375171 378545151 28 CHOOSE
1 95902 2008-10-30 02:25:42 3487375171 378545151 28 CHOOSE
1 95901 2008-10-30 02:05:42 3487375171 378545151 28 CHOOSE
1 95900 2008-10-30 01:45:42 3487375171 378545151 28 CHOOSE
1 95899 2008-10-30 01:25:42 3487375171 378545151 28 CHOOSE
1 95898 2008-10-30 01:05:42 3487375171 378545151 28 CHOOSE
1 95897 2008-10-30 00:45:43 3487375171 378545151 28 CHOOSE
1 95896 2008-10-30 00:25:42 3487375171 378545151 28 CHOOSE
1 95895 2008-10-30 00:05:43 3487375171 378545151 28 CHOOSE
1 95894 2008-10-29 23:45:42 3487375171 378545151 28 CHOOSE
1 95883 2008-10-29 23:25:42 3487375171 378545151 28 CHOOSE
1 95881 2008-10-29 22:45:42 3487375171 177359624 223 CHOOSE
1 95880 2008-10-29 22:25:41 3487375171 177359624 223 CHOOSE
1 95879 2008-10-29 22:05:42 3487375171 177359624 223 CHOOSE
1 95878 2008-10-29 21:45:42 3487375171 177359624 223 CHOOSE
1 95877 2008-10-29 21:25:42 3487375171 177359624 223 CHOOSE
1 95876 2008-10-29 21:05:42 3487375171 177359624 223 CHOOSE
1 95875 2008-10-29 20:45:42 3487375171 177359624 223 CHOOSE
1 95874 2008-10-29 20:25:42 3487375171 177359624 223 CHOOSE
1 95863 2008-10-29 20:05:42 3487375171 177359624 223 CHOOSE
1 95862 2008-10-29 19:45:42 3487375171 177359624 223 CHOOSE
1 95861 2008-10-29 19:25:42 3487375171 177359624 223 CHOOSE
1 95860 2008-10-29 19:05:42 3487375171 177359624 223 CHOOSE
1 95859 2008-10-29 18:45:42 3487375171 177359624 223 CHOOSE
1 95858 2008-10-29 18:25:42 3487375171 177359624 223 CHOOSE
1 95857 2008-10-29 18:05:41 3487375171 177359624 223 CHOOSE
1 95856 2008-10-29 17:45:41 3487375171 177359624 223 CHOOSE
1 95855 2008-10-29 17:25:41 3487375171 177359624 223 CHOOSE
1 95854 2008-10-29 17:05:42 3487375171 177359624 223 CHOOSE
1 95838 2008-10-29 16:45:42 3487375171 177359624 223 CHOOSE
1 95805 2008-10-29 11:05:41 3487375171 177359624 223 CHOOSE
1 95761 2008-10-29 08:05:41 3487375171 177359624 223 CHOOSE
1 95760 2008-10-29 07:45:41 3487375171 177359624 223 CHOOSE
1 95759 2008-10-29 07:25:41 3487375171 177359624 223 CHOOSE
1 95758 2008-10-29 07:05:42 3487375171 177359624 223 CHOOSE
1 95757 2008-10-29 06:45:41 3487375171 177359624 223 CHOOSE
1 95756 2008-10-29 06:25:40 3487375171 177359624 223 CHOOSE
1 95755 2008-10-29 06:05:41 3487375171 177359624 223 CHOOSE
1 95754 2008-10-29 05:45:41 3487375171 177359624 223 CHOOSE
1 95743 2008-10-29 05:25:41 3487375171 177359624 223 CHOOSE
1 95742 2008-10-29 05:05:41 3487375171 177359624 223 CHOOSE
1 95741 2008-10-29 04:45:40 3487375171 177359624 223 CHOOSE
1 95740 2008-10-29 04:25:41 3487375171 177359624 223 CHOOSE
1 95739 2008-10-29 04:05:40 3487375171 177359624 223 CHOOSE
1 95738 2008-10-29 03:45:40 3487375171 177359624 223 CHOOSE
1 95737 2008-10-29 03:25:41 3487375171 177359624 223 CHOOSE
1 95736 2008-10-29 03:05:40 3487375171 177359624 223 CHOOSE
1 95735 2008-10-29 02:45:41 3487375171 177359624 223 CHOOSE
1 95734 2008-10-29 02:25:42 3487375171 177359624 223 CHOOSE
1 95723 2008-10-29 02:05:40 3487375171 177359624 223 CHOOSE
1 95722 2008-10-29 01:45:41 3487375171 177359624 223 CHOOSE
1 95721 2008-10-29 01:25:41 3487375171 177359624 223 CHOOSE
1 95720 2008-10-29 01:05:41 3487375171 177359624 223 CHOOSE
1 95719 2008-10-29 00:45:41 3487375171 177359624 223 CHOOSE
1 95718 2008-10-29 00:25:41 3487375171 177359624 223 CHOOSE
1 95717 2008-10-29 00:05:40 3487375171 177359624 223 CHOOSE
1 95716 2008-10-28 23:45:40 3487375171 177359624 223 CHOOSE
1 95715 2008-10-28 23:25:40 3487375171 177359624 223 CHOOSE
1 95714 2008-10-28 23:05:40 3487375171 177359624 223 CHOOSE
1 95703 2008-10-28 22:45:40 3487375171 177359624 223 CHOOSE
1 95702 2008-10-28 22:25:40 3487375171 177359624 223 CHOOSE
1 95701 2008-10-28 22:05:40 3487375171 177359624 223 CHOOSE
1 95700 2008-10-28 21:45:40 3487375171 177359624 223 CHOOSE
1 95699 2008-10-28 21:25:39 3487375171 177359624 223 CHOOSE
1 95698 2008-10-28 21:05:40 3487375171 177359624 223 CHOOSE
1 95697 2008-10-28 20:45:40 3487375171 177359624 223 CHOOSE
1 95696 2008-10-28 20:25:40 3487375171 177359624 223 CHOOSE
1 95695 2008-10-28 20:05:40 3487375171 177359624 223 CHOOSE
1 95694 2008-10-28 19:45:40 3487375171 177359624 223 CHOOSE
1 95683 2008-10-28 19:25:40 3487375171 177359624 223 CHOOSE
1 95682 2008-10-28 19:05:40 3487375171 177359624 223 CHOOSE
1 95681 2008-10-28 18:45:40 3487375171 177359624 223 CHOOSE
1 95680 2008-10-28 18:25:41 3487375171 177359624 223 CHOOSE
1 95679 2008-10-28 18:05:40 3487375171 177359624 223 CHOOSE
1 95678 2008-10-28 17:45:39 3487375171 177359624 223 CHOOSE
1 95677 2008-10-28 17:25:41 3487375171 177359624 223 CHOOSE
1 95676 2008-10-28 17:05:40 3487375171 177359624 223 CHOOSE
1 95664 2008-10-28 16:05:41 3487375171 177359624 223 CHOOSE
1 95607 2008-10-28 12:25:40 3487375171 177359624 223 CHOOSE
1 95606 2008-10-28 12:05:40 3487375171 177359624 223 CHOOSE
1 95605 2008-10-28 11:45:39 3487375171 177359624 223 CHOOSE
------------------------------------------- Instance 2 ------------------------------------
INSTANCE_NUMBER SNAP_ID SNAP_TIME HASH_VALUE PLAN_HASH_VALUE COST OPTIMIZER
--------------- ------- ------------------- ---------- --------------- ---------- ----------
2 95954 2008-10-30 09:05:43 3487375171 378545151 28 CHOOSE
2 95933 2008-10-30 08:45:43 3487375171 378545151 28 CHOOSE
2 95932 2008-10-30 08:25:43 3487375171 378545151 28 CHOOSE
2 95931 2008-10-30 08:05:43 3487375171 378545151 28 CHOOSE
2 95930 2008-10-30 07:45:43 3487375171 378545151 28 CHOOSE
2 95929 2008-10-30 07:25:43 3487375171 378545151 28 CHOOSE
2 95928 2008-10-30 07:05:43 3487375171 378545151 28 CHOOSE
2 95927 2008-10-30 06:45:43 3487375171 378545151 28 CHOOSE
2 95926 2008-10-30 06:25:42 3487375171 378545151 28 CHOOSE
2 95925 2008-10-30 06:05:42 3487375171 378545151 28 CHOOSE
2 95924 2008-10-30 05:45:42 3487375171 378545151 28 CHOOSE
2 95913 2008-10-30 05:25:43 3487375171 378545151 28 CHOOSE
2 95912 2008-10-30 05:05:42 3487375171 378545151 28 CHOOSE
2 95911 2008-10-30 04:45:43 3487375171 378545151 28 CHOOSE
2 95910 2008-10-30 04:25:43 3487375171 378545151 28 CHOOSE
2 95909 2008-10-30 04:05:42 3487375171 378545151 28 CHOOSE
2 95908 2008-10-30 03:45:42 3487375171 378545151 28 CHOOSE
2 95907 2008-10-30 03:25:42 3487375171 378545151 28 CHOOSE
2 95906 2008-10-30 03:05:43 3487375171 378545151 28 CHOOSE
2 95905 2008-10-30 02:45:42 3487375171 378545151 28 CHOOSE
2 95904 2008-10-30 02:25:42 3487375171 378545151 28 CHOOSE
2 95893 2008-10-30 02:05:42 3487375171 378545151 28 CHOOSE
2 95892 2008-10-30 01:45:42 3487375171 378545151 28 CHOOSE
2 95891 2008-10-30 01:25:42 3487375171 378545151 28 CHOOSE
2 95890 2008-10-30 01:05:42 3487375171 378545151 28 CHOOSE
2 95889 2008-10-30 00:45:43 3487375171 378545151 28 CHOOSE
2 95888 2008-10-30 00:25:42 3487375171 378545151 28 CHOOSE
2 95887 2008-10-30 00:05:43 3487375171 378545151 28 CHOOSE
2 95886 2008-10-29 23:45:42 3487375171 378545151 28 CHOOSE
2 95885 2008-10-29 23:25:42 3487375171 378545151 28 CHOOSE
2 95873 2008-10-29 22:45:42 3487375171 177359624 223 CHOOSE
2 95872 2008-10-29 22:25:41 3487375171 177359624 223 CHOOSE
2 95871 2008-10-29 22:05:42 3487375171 177359624 223 CHOOSE
2 95870 2008-10-29 21:45:42 3487375171 177359624 223 CHOOSE
2 95869 2008-10-29 21:25:42 3487375171 177359624 223 CHOOSE
2 95868 2008-10-29 21:05:42 3487375171 177359624 223 CHOOSE
2 95867 2008-10-29 20:45:42 3487375171 177359624 223 CHOOSE
2 95866 2008-10-29 20:25:42 3487375171 177359624 223 CHOOSE
2 95865 2008-10-29 20:05:42 3487375171 177359624 223 CHOOSE
2 95864 2008-10-29 19:45:42 3487375171 177359624 223 CHOOSE
2 95853 2008-10-29 19:25:42 3487375171 177359624 223 CHOOSE
2 95852 2008-10-29 19:05:41 3487375171 177359624 223 CHOOSE
2 95851 2008-10-29 18:45:42 3487375171 177359624 223 CHOOSE
2 95850 2008-10-29 18:25:42 3487375171 177359624 223 CHOOSE
2 95849 2008-10-29 18:05:42 3487375171 177359624 223 CHOOSE
2 95848 2008-10-29 17:45:41 3487375171 177359624 223 CHOOSE
2 95847 2008-10-29 17:25:41 3487375171 177359624 223 CHOOSE
2 95846 2008-10-29 17:05:42 3487375171 177359624 223 CHOOSE
2 95845 2008-10-29 16:45:42 3487375171 177359624 223 CHOOSE
2 95844 2008-10-29 16:25:42 3487375171 177359624 223 CHOOSE
2 95830 2008-10-29 16:05:42 3487375171 177359624 223 CHOOSE
2 95827 2008-10-29 15:05:42 3487375171 177359624 223 CHOOSE
2 95826 2008-10-29 14:45:41 3487375171 177359624 223 CHOOSE
2 95825 2008-10-29 14:25:41 3487375171 177359624 223 CHOOSE
2 95824 2008-10-29 14:05:42 3487375171 177359624 223 CHOOSE
2 95803 2008-10-29 13:45:41 3487375171 177359624 223 CHOOSE
2 95802 2008-10-29 13:25:41 3487375171 177359624 223 CHOOSE
2 95801 2008-10-29 13:05:42 3487375171 177359624 223 CHOOSE
2 95800 2008-10-29 12:45:41 3487375171 177359624 223 CHOOSE
2 95799 2008-10-29 12:25:41 3487375171 177359624 223 CHOOSE
2 95798 2008-10-29 12:05:41 3487375171 177359624 223 CHOOSE
2 95797 2008-10-29 11:45:41 3487375171 177359624 223 CHOOSE
2 95796 2008-10-29 11:25:41 3487375171 177359624 223 CHOOSE
2 95794 2008-10-29 10:45:42 3487375171 177359624 223 CHOOSE
2 95787 2008-10-29 10:25:41 3487375171 177359624 223 CHOOSE
2 95785 2008-10-29 09:45:41 3487375171 177359624 223 CHOOSE
2 95771 2008-10-29 08:25:41 3487375171 177359624 223 CHOOSE
2 95770 2008-10-29 08:05:41 3487375171 177359624 223 CHOOSE
2 95769 2008-10-29 07:45:41 3487375171 177359624 223 CHOOSE
2 95768 2008-10-29 07:25:41 3487375171 177359624 223 CHOOSE
2 95767 2008-10-29 07:05:41 3487375171 177359624 223 CHOOSE
2 95766 2008-10-29 06:45:41 3487375171 177359624 223 CHOOSE
2 95765 2008-10-29 06:25:40 3487375171 177359624 223 CHOOSE
2 95764 2008-10-29 06:05:41 3487375171 177359624 223 CHOOSE
2 95753 2008-10-29 05:45:41 3487375171 177359624 223 CHOOSE
2 95752 2008-10-29 05:25:41 3487375171 177359624 223 CHOOSE
2 95751 2008-10-29 05:05:41 3487375171 177359624 223 CHOOSE
2 95750 2008-10-29 04:45:40 3487375171 177359624 223 CHOOSE
2 95749 2008-10-29 04:25:41 3487375171 177359624 223 CHOOSE
2 95748 2008-10-29 04:05:40 3487375171 177359624 223 CHOOSE
2 95747 2008-10-29 03:45:40 3487375171 177359624 223 CHOOSE
2 95746 2008-10-29 03:25:41 3487375171 177359624 223 CHOOSE
2 95745 2008-10-29 03:05:40 3487375171 177359624 223 CHOOSE
2 95744 2008-10-29 02:45:41 3487375171 177359624 223 CHOOSE
2 95733 2008-10-29 02:25:41 3487375171 177359624 223 CHOOSE
2 95732 2008-10-29 02:05:40 3487375171 177359624 223 CHOOSE
2 95731 2008-10-29 01:45:41 3487375171 177359624 223 CHOOSE
2 95730 2008-10-29 01:25:40 3487375171 177359624 223 CHOOSE
2 95729 2008-10-29 01:05:40 3487375171 177359624 223 CHOOSE
2 95728 2008-10-29 00:45:41 3487375171 177359624 223 CHOOSE
2 95727 2008-10-29 00:25:41 3487375171 177359624 223 CHOOSE
2 95726 2008-10-29 00:05:40 3487375171 177359624 223 CHOOSE
2 95725 2008-10-28 23:45:40 3487375171 177359624 223 CHOOSE
2 95724 2008-10-28 23:25:40 3487375171 177359624 223 CHOOSE
2 95713 2008-10-28 23:05:40 3487375171 177359624 223 CHOOSE
2 95712 2008-10-28 22:45:40 3487375171 177359624 223 CHOOSE
2 95711 2008-10-28 22:25:40 3487375171 177359624 223 CHOOSE
2 95710 2008-10-28 22:05:40 3487375171 177359624 223 CHOOSE
2 95709 2008-10-28 21:45:40 3487375171 177359624 223 CHOOSE
2 95708 2008-10-28 21:25:39 3487375171 177359624 223 CHOOSE
2 95707 2008-10-28 21:05:40 3487375171 177359624 223 CHOOSE
2 95706 2008-10-28 20:45:40 3487375171 177359624 223 CHOOSE
2 95705 2008-10-28 20:25:40 3487375171 177359624 223 CHOOSE
2 95704 2008-10-28 20:05:40 3487375171 177359624 223 CHOOSE
2 95693 2008-10-28 19:45:40 3487375171 177359624 223 CHOOSE
2 95692 2008-10-28 19:25:40 3487375171 177359624 223 CHOOSE
2 95691 2008-10-28 19:05:40 3487375171 177359624 223 CHOOSE
2 95690 2008-10-28 18:45:40 3487375171 177359624 223 CHOOSE
2 95689 2008-10-28 18:25:40 3487375171 177359624 223 CHOOSE
2 95684 2008-10-28 16:45:40 3487375171 177359624 223 CHOOSE
2 95656 2008-10-28 16:25:40 3487375171 177359624 223 CHOOSE
2 95655 2008-10-28 16:05:41 3487375171 177359624 223 CHOOSE
2 95602 2008-10-28 13:45:40 3487375171 177359624 223 CHOOSE
2 95601 2008-10-28 13:25:40 3487375171 177359624 223 CHOOSE
2 95600 2008-10-28 13:05:40 3487375171 177359624 223 CHOOSE
2 95599 2008-10-28 12:45:40 3487375171 177359624 223 CHOOSE
2 95598 2008-10-28 12:25:40 3487375171 177359624 223 CHOOSE
2 95597 2008-10-28 12:05:40 3487375171 177359624 223 CHOOSE
2 95596 2008-10-28 11:45:39 3487375171 177359624 223 CHOOSE
2 95595 2008-10-28 11:25:40 3487375171 177359624 223 CHOOSE
2 95594 2008-10-28 11:05:40 3487375171 177359624 223 CHOOSE
2 95567 2008-10-28 10:45:39 3487375171 177359624 223 CHOOSE
可以看出,在2008-10-29 23:25左右时执行计划发生了改变。
查看历史执执行计划:(通过查询v$sql_plan,使用plan_hash_value)
[Execution Plan Information]
--------------------------------------------------------------------------------------------------
| Operation | PHV/Object Name | Rows | Bytes| Cost |
--------------------------------------------------------------------------------------------------
|00[00]SELECT STATEMENT |plan_hash_value 17735| | | 216 |
|01[01]SORT ORDER BY | | 1 | 207 | 216 |
|02[02] FILTER | | | | |
|03[03] TABLE ACCESS BY INDEX ROWID |SYS_FIELD_DESC | 1 | 43 | 2 |
|04[04] NESTED LOOPS | | 1 | 207 | 200 |
|05[05] NESTED LOOPS OUTER | | 1 | 164 | 198 |
|06[06] NESTED LOOPS | | 1 | 111 | 197 |
|07[07] MERGE JOIN CARTESIAN | | 1 | 65 | 5 |
|08[08] TABLE ACCESS FULL |SYS_FIELD_DESC | 1 | 43 | 2 |
|09[08] BUFFER SORT | | 1 | 22 | 3 |
|10[09] TABLE ACCESS BY INDEX ROWID |ACCT_75 | 1 | 22 | 3 |
|11[10] INDEX RANGE SCAN |IDX_ACCT_CODE_75 | 1 | | 2 |
|12[07] TABLE ACCESS BY GLOBAL INDEX ROWID |PT_75 | 1 | 46 | 192 |
|13[08] INDEX RANGE SCAN |IDX_PT_75_ACCTI | 11 | | 2 |
|14[06] VIEW PUSHED PREDICATE | | 9 | 477 | 1 |
|15[07] NESTED LOOPS OUTER | | 1 | 53 | 7 |
|16[08] NESTED LOOPS OUTER | | 1 | 38 | 6 |
|17[09] NESTED LOOPS OUTER | | 1 | 26 | 4 |
|18[10] TABLE ACCESS BY INDEX ROWID |SYS_OPERATOR | 1 | 14 | 2 |
|19[11] INDEX UNIQUE SCAN |PK_SYS_OPERATOR | 1 | | 1 |
|20[10] TABLE ACCESS BY INDEX ROWID |PARTY_ROLE | 1 | 12 | 2 |
|21[11] INDEX RANGE SCAN |IDX_PARTYROLE_PARTY_ | 1 | | 1 |
|22[09] TABLE ACCESS BY INDEX ROWID |PARTY_ROLE_RELAT | 1 | 12 | 2 |
|23[10] INDEX RANGE SCAN |IDX_PARTY2_ROLE_ID | 1 | | 1 |
|24[08] TABLE ACCESS BY INDEX ROWID |PARTY_ROLE | 1 | 15 | 1 |
|25[09] INDEX UNIQUE SCAN |PK_PARTY_ROLE | 1 | | |
|26[05] INDEX RANGE SCAN |SYS_FIELD_DESC_1 | 1 | | 1 |
--------------------------------------------------------------------
通过对比前后执行计划,可以看出,之前的执行计划,走索引IDX_PT_75_ACCTI,而当前走索引IDX_PT_75_DAY。
通过查询dba_objects,发现IDX_PT_75_DAY正是10月29号23点创建的。因而导致了执行计划的改变。
SQL>SELECT owner, object_name, object_type, created, last_ddl_time, status
2 FROM dba_objects
3 WHERE object_name ='IDX_PT_75_DAY';
OWNER OBJECT_NAME OBJECT_TYPE CREATED LAST_DDL_TIME STATUS
-------- ------------------- ------------ ------------------- ------------------- ------
PGATE IDX_PT_75_DAY INDEX 2008-10-29 23:05:22 2008-10-29 23:05:22 VALID
通知应用开发人员,开发人员DROP IDX_PT_75_DAY索引后,数据库恢复正常。
查看执行计划信息:
---------------------------------------------- Instance 1 ------------------------------------
INSTANCE_NUMBER SNAP_ID SNAP_TIME HASH_VALUE PLAN_HASH_VALUE COST OPTIMIZER
--------------- ---------- ------------------- ---------- --------------- ---------- ----------
1 95991 2008-10-30 12:25:43 3487375171 177359624 223 CHOOSE
1 95990 2008-10-30 12:05:43 3487375171 177359624 223 CHOOSE
1 95989 2008-10-30 11:45:43 3487375171 177359624 223 CHOOSE
1 95985 2008-10-30 10:25:43 3487375171 177359624 223 CHOOSE
1 95985 2008-10-30 10:25:43 3487375171 378545151 28 CHOOSE
---------------------------------------------- Instance 2 ------------------------------------
INSTANCE_NUMBER SNAP_ID SNAP_TIME HASH_VALUE PLAN_HASH_VALUE COST OPTIMIZER
--------------- ---------- ------------------- ---------- --------------- ---------- ----------
2 95983 2008-10-30 12:45:43 3487375171 177359624 223 CHOOSE
2 95982 2008-10-30 12:25:43 3487375171 177359624 223 CHOOSE
2 95981 2008-10-30 12:05:43 3487375171 177359624 223 CHOOSE
2 95980 2008-10-30 11:45:43 3487375171 177359624 223 CHOOSE
2 95977 2008-10-30 10:45:43 3487375171 177359624 223 CHOOSE
2 95976 2008-10-30 10:25:43 3487375171 177359624 223 CHOOSE
2 95976 2008-10-30 10:25:43 3487375171 378545151 28 CHOOSE
执行计划已恢复正常。
查看当前执行计划:
[Execution Plan Information]
--------------------------------------------------------------------------------------------------
| Operation | PHV/Object Name | Rows | Bytes| Cost |
--------------------------------------------------------------------------------------------------
|00[00]SELECT STATEMENT |---- 3487375171.0 ---| | | 223 |
|01[01]SORT ORDER BY | | 1 | 218 | 223 |
|02[02] FILTER | | | | |
|03[03] TABLE ACCESS BY INDEX ROWID |SYS_FIELD_DESC | 1 | 43 | 2 |
|04[04] NESTED LOOPS | | 1 | 218 | 207 |
|05[05] NESTED LOOPS OUTER | | 1 | 175 | 205 |
|06[06] NESTED LOOPS | | 1 | 117 | 204 |
|07[07] MERGE JOIN CARTESIAN | | 1 | 65 | 6 |
|08[08] TABLE ACCESS FULL |SYS_FIELD_DESC | 1 | 43 | 2 |
|09[08] BUFFER SORT | | 1 | 22 | 4 |
|10[09] TABLE ACCESS BY INDEX ROWID |ACCT_75 | 1 | 22 | 4 |
|11[10] INDEX RANGE SCAN |IDX_ACCT_CODE_75 | 1 | | 2 |
|12[07] TABLE ACCESS BY GLOBAL INDEX ROWID |PT_75 | 1 | 52 | 198 |
|13[08] INDEX RANGE SCAN |IDX_PT_75_ACCTI | 11 | | 2 |
|14[06] VIEW PUSHED PREDICATE | | 10 | 580 | 1 |
|15[07] NESTED LOOPS OUTER | | 1 | 58 | 7 |
|16[08] NESTED LOOPS OUTER | | 1 | 42 | 6 |
|17[09] NESTED LOOPS OUTER | | 1 | 29 | 4 |
|18[10] TABLE ACCESS BY INDEX ROWID |SYS_OPERATOR | 1 | 15 | 2 |
|19[11] INDEX UNIQUE SCAN |PK_SYS_OPERATOR | 1 | | 1 |
|20[10] TABLE ACCESS BY INDEX ROWID |PARTY_ROLE | 1 | 14 | 2 |
|21[11] INDEX RANGE SCAN |IDX_PARTYROLE_PARTY_ | 1 | | 1 |
|22[09] TABLE ACCESS BY INDEX ROWID |PARTY_ROLE_RELAT | 1 | 13 | 2 |
|23[10] INDEX RANGE SCAN |IDX_PARTY2_ROLE_ID | 1 | | 1 |
|24[08] TABLE ACCESS BY INDEX ROWID |PARTY_ROLE | 1 | 16 | 1 |
|25[09] INDEX UNIQUE SCAN |PK_PARTY_ROLE | 1 | | |
|26[05] INDEX RANGE SCAN |SYS_FIELD_DESC_1 | 1 | | 1 |
--------------------------------------------------------------------
[Predicate Information]
--------------------------------------------------------------------
2 filter::2< =:3
3 filter:"A"."PAYED_METHOD"="D"."VALUE"
8 filter:"C"."TABLE_NAME"='PT' AND "C"."COLUMN_NAME"='CERTIFICATE_T
YPE'
11 access:"B"."ACCT_CODE"=:1
12 filter:"A"."AMOUNT"<>0 AND "A"."CERTIFICATE_TYPE"="C"."VALUE" AND TO_C
HAR("A"."PAY_DATE",'yyyymmdd')>=:2 AND TO_CHAR("A"."PAY_DATE",'yyyymmd
d')< =:3
13 access:"A"."ACCT_ID"="B"."ACCT_ID"
18 filter:NVL("X"."REGION_ID",0)=75 OR NVL("X"."REGION_ID",0)=0
19 access:"A"."STAFF_ID"="X"."OPERATOR_ID"
21 access:"X"."PARTY_ID"="Y"."PARTY_ID"(+)
23 access:"Y"."PARTY_ROLE_ID"="Z"."PARTY2_ROLE_ID"(+)
25 access:"Z"."PARTY1_ROLE_ID"="O"."PARTY_ROLE_ID"(+)
26 access:"D"."TABLE_NAME"='PT_PLAN' AND "D"."COLUMN_NAME"='PT_
METHOD'
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22578826/viewspace-741756/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/22578826/viewspace-741756/
对比前后执行计划,发现问题 - 9i相关推荐
- Oceanbase和TiDB粗浅对比之 - 执行计划
一.前言 OceanBase和TiDB作为国内2款的比较流行的兼容MySQL协议的开源数据库使用者也越来越多,两种数据库不仅在架构原理上有较大差异,在开源方式上有较大的不同: TiDB 采用的Apac ...
- oracle清除执行计划,Oracle数据库9I中清除特定表相关执行计划案例
天萃荷净 在9i中因为某个执行计划因为Oracle Peeking绑定变量的控制导致现有的执行计划不正确,需要清除掉这条sql语句的执行计划.在10g中提供了dbms_shared_pool.purg ...
- 查看ORACLE的实际执行计划
ORACLE的执行计划分为预估执行计划和实际执行计划.其中,你用Toad.PL/SQL Developer.SQL Developer.EXPLAIN PLAN FOR或者SET ATUOTRACE ...
- 【云和恩墨大讲堂】从执行计划洞察ORACLE优化器的“小聪明”
作者简介 黄浩 惠普 十年一剑,十年磨砺.3年通信行业,写就近3万条SQL:5年制造行业,遨游在ETL的浪潮:2年性能优化,厚积薄发自成一家 主题介绍: Oracle执行计划的另类解读:调皮的执行计 ...
- Oracle执行计划中 并行和BUFFER SORT的问题
近日开发说某个系统上有个sql执行时间忽快忽慢,让我帮忙看下,此sql是4个表(2个千万,2个十万)进行inner join操作,最后进行count(*)聚合操作,执行时间1--10S不等.查看执行计 ...
- 6.读懂mysql执行计划
文章目录 1.执行计划概念和语法 1.执行计划的概念 2.执行计划的语法 1.常规执行计划语法 2.扩展执行计划的语法 3.分区表的执行计划语法 2.执行计划包含的信息 1.id:查询的顺序 2.s ...
- oracle执行计划案例,返璞归真 - Oracle 9i的RBO执行计划案例
预计阅读时间:15分钟 最近配合DBA团队,做了一次Oracle 9i老旧应用的搬迁工作,偶然发现应用某一个逻辑,执行缓慢,进而根据代码,找到对应的SQL语句,分析过程,还是有些意思,也暴露了些问题. ...
- Oracle进阶篇之查看执行计划
目录 一.查看执行计划的方式 1.1.设置autotrace 1.2.使用第三方工具 1.3.EXPLAIN PLAN FOR 二.清除SGA缓存 三.分析执行计划 3.1.创建测试表 3.2.查看执 ...
- Mysql高级调优篇——第二章:Explain执行计划深度剖析
1.Mysql Query Optimizer 这个名称在前言部分我在Mysql的整体架构中介绍过,称为查询优化器:这个查询优化器在绝大多数的公司,是不会做任何修改和扩展的,因为业务不需要,大牛请不起 ...
最新文章
- 2017年前端开发工具趋势
- 算法:搜索插入的位置
- Day8 Python基础之遗漏知识点(六)
- Linux 设备树device tree 使用手册
- 面试精讲之面试考点及大厂真题 - 分布式专栏 09 缓存必问:Reids持久化,高可用集群
- Postgresql 帐号密码修改方法
- 【原创】大叔问题定位分享(33)beeline连接presto报错
- 某程序员的薪水变化数据
- 10-微信小程序商城 分类和产品 产品列表(微信小程序商城开发、小程序毕业设计、小程序源代码)(黄菊华-微信小程序开发教程)
- GEEK学习笔记— —程序员面试宝典笔记(四)
- 消息队列,问题与处理方案梳理
- d3.js之中国地图
- JAVA实现排列组合
- 深入理解Android相机体系结构
- 微信小程序相册-笔记1
- 【文献阅读】受山体阴影影响的冰湖制图方法研究(Li JunLi等人,2018.09,IJRS)
- 编程语言中,还有一种语言,那就是用中文来编程
- 【LeetCode】825. Friends Of Appropriate Ages 解题报告(Python)
- 字符串转换成字符数组的一些方法
- 【时间序列】从 ICLR 2022 投稿中了解图神经网络和时间序列相结合的研究趋势...
热门文章
- MySQL数据库——语句
- c++nullptr(空指针常量)、constexpr(常量表达式)
- 股市学习稳扎稳打(一)认识市场上的各路游资
- 微博超话显示服务器有点累,刚才手机刷微博,刷新了一下首页... - @菜菜_fz 的微博精选 - 微博国际站...
- 面试专题:苹果树(Qtrade)二面三面
- Android的隐私沙盒,与iOS隐私政策有哪些不同?
- 微服务与宏服务?故事线-基本概念(理解)
- JAVA第二次作业《胖瘦程度计算》
- 淘淘商城第78讲——查询商品详情添加缓存的分析
- silver searcher ag 命令文档