weixin_36752065 2017-10-27 06:56 采纳率: 14.3%
浏览 1797

SQL执行中函数sum的问题

今天在查询一张数据量很大的表时,假设表为A,其中有本金字段和利息字段,现在要去将23号到26号这三天的本金和利息的总和取出来。
查询一:select sum(本金),sum(利息) from A where 时间在23号到26号之间; 执行时间100s左右
查询二: select sum(本金),sum(利息) from
(select 本金,利息 form A where 时间在23号到26号之间 );
这样只要10S左右。
个人理解:按照SQL的执行顺序,不应该会差别这么大。
求大神解释一下!

  • 写回答

3条回答

  • mj200961 2017-10-27 07:04
    关注

    应该是查询二缩小主查询的范围,查询一需要去全表扫描

    评论

报告相同问题?

悬赏问题

  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!