网站首页
JSP空间
动态资讯
开源项目
技术文档
资源下载
J2EE资源
客户论坛
在线支付
 
  技术文档>>数据库技术>>Oracle技术>>Oracle开发>查看文档  
  视图上含有row_number分析函数没法走索引     
  文章作者:未知  文章来源:赛迪网技术社区  
  查看:117次  录入:管理员--2008-03-10  
 

问题:有如下的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

 
 
上一篇: linux自动备份mysql数据库的实用方法    下一篇: 如何调整"oracle"数据库服务器的性能
  相关文档
[Oracle]一次数据库性能问题的tuning 08-05
深入讲解memory_target与自动内存管理 03-24
Oracle9i与SYBASE ASE12.5相比的几个不足 08-05
深入讲解"database link"的设置和使用 03-12
不要忽视Oracle 10g STATSPACK新功能 06-03
通过JDBC连接Oracle数据库的十大技巧 04-11
轻松掌握"lag"与"lead"分析函?的用法 02-29
详细讲解oracle sql*loader的使用方法 08-18
教你快速掌握oracle数据库的备份策略 04-14
oracle数据库中获取固定记录数的实用方法 04-15
使用type方式,解决in列表过长的问题 (1) 02-27
Oracle数据库最重要的部分之一数据字典 09-29
几种解决互联网应用程序开发的好方法 (1) 03-28
如何用dbms_rowid获取rowid的详细信息 03-26
oracle 数据库唯一约束中的null的处理 09-05
丢失归档日志文件后数据库应当如何恢复 (1) 04-16
个人经验总结──生产环境下的备份方案 06-10
解决启动数据库时发生的ora-12528错误 03-14
借助两个开发包在pl/sql中实现多进程通信 06-20
Oracle *Graphics中不同类型图形的切换 09-01
返回首页 | 关于我们 | J网章程 | JSP空间合租 | 客服中心 | 免责声明 | 常见问题 | 参观机房
本站主机空间代理至厦门市华众网络科技有限公司
《中华人民共和国增值电信业务经营许可证》
编号:闽B2-20050079
@2005-2008福建JSP技术网 版权所有 闽ICP备05000928号
厦门(总部):13616026886 福州:0591-87655121
邮箱:admin@fjjsp.com 站长QQ,点击这里给我发消息