分类: Oracle
2008-03-30 22:52:46
来源:赛迪网 作者:Alice |
问题:有如下的sql性能差:
select rowid,PKG_LIFE_QUERY_FUNC.F_GET_DEPOSIT_ACCOUNT_VALUE(DEPOSIT_ID,ACCOUNT_CODE) as ACCOUNT_VALUE,PKG_LIFE_QUERY_FUNC.F_GET_DEPOSIT_ACCOUNT_VALUE(DEPOSIT_ID,ACCOUNT_CODE) as ACCOUNT_VALUE,a.* from V_CUST_DEPOSIT_LIST a where ( account_code='27902')
V_CUST_DEPOSIT_LIST 是一个视图如下:
create or replace view v_cust_deposit_list as
select row_number() over(order by tcdl.account_code,
trunc(tcdl.deposit_date), to_number(decode(tcd.distri_type,
'1', 1, '2', 5, '3', decode(tpf.fee_type, 169, 2, 69, 6),
'10', 3, '71', 4, '8', 9, 8))) rn,tcdl.*
from t_cust_deposit_list tcdl,
t_capital_distribute tcd,
t_product_fee tpf
where tcdl.capital_id = tcd.capital_id(+)
and tcd.prem_id = tpf.list_id(+)
order by tcdl.account_code,
trunc(tcdl.deposit_date),
to_number(decode(tcd.distri_type,'1',1,'2',5,'3',
decode(tpf.fee_type, 169, 2, 69, 6),'10',3,'71',4,'8',9,8));
在t_cust_deposit_list有account_code;
原因:由于在视图上含有row_number分析函数,所以没法走索引:把语句改为:
select rowid,
PKG_LIFE_QUERY_FUNC.F_GET_DEPOSIT_ACCOUNT_VALUE(DEPOSIT_ID,ACCOUNT_CODE) as ACCOUNT_VALUE,
PKG_LIFE_QUERY_FUNC.F_GET_DEPOSIT_ACCOUNT_VALUE(DEPOSIT_ID,ACCOUNT_CODE) as ACCOUNT_VALUE,
a.*
from (
select row_number() over (order by tcdl.account_code,trunc(tcdl.deposit_date),to_number(decode(tcd.distri_type,'1',1,'3',decode(tpf.fee_type,169,2,69,5),'10',3,'71',4,'2',9,8))) rn,tcdl.*
from
(select tcd2.* from t_cust_deposit_list tcd2
where tcd2.account_code='27902') tcdl,t_capital_distribute tcd,t_product_fee tpf
where tcdl.capital_id = tcd.capital_id(+) and tcd.prem_id = tpf.list_id(+)
order by tcdl.account_code,trunc(tcdl.deposit_date),to_number(decode(tcd.distri_type,'1',1,'3',decode(tpf.fee_type,169,2,69,5),'10',3,'71',4,'2',9,8))
) a |