oracle优化聚合,SUM等聚合函数的优化

本帖最后由 dotaddjj 于 2014-8-25 11:38 编辑

我个人认为这两个sql没有可比性,首先第一个sql语句select SUM(origin_value) from ATable这个如果这个列上面有索引,走全索引快速扫描是最优秀的,一般而言索引的大小肯定比表小,那么多块读时段的大小会决定cbo选择那种执行方式,一般是全索引快速扫描,至于你这个为什么没有走该列上面的全索引扫描,个人也比较奇怪,这个对于该列是否有not null约束没影响的,因为null值sum后结果也不会变。

[oracle@dbserver ~]$ sqlplus / as sysdba

SQL*Plus: Release 11.2.0.1.0 Production on Mon Aug 25 10:05:29 2014

Copyright (c) 1982, 2009, Oracle.  All rights reserved.

Connected to:

Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production

With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> select sum(object_id) from ta;

Execution Plan

----------------------------------------------------------

Plan hash value: 1383641628

-----------------------------------------------------------------

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值