杨jun坚 2019-12-21 10:20 采纳率: 0%
浏览 315
已结题

oracle中一段sql查询优化的思考,第一段sql是原来的,第二段是优化的sql,想问下为什么第一段会那么慢?

oracle中一段sql查询优化的思考,第一段sql是原来的,第二段是优化的sql,想问下为什么第一段会那么慢?
INFO_TB_XXX_LIVE 数据量300万+,INFO_TB_XXX 数据量800万+

第一段

select b.id, 
(select count(l.id) from INFO_TB_XXX_LIVE l where l.build_id = b.id and l.del_flag = '0' and l.LIVE_EDATE IS NULL) as LIVE_COUNT 

from INFO_TB_XXX b

第二段

select b.id id,
count(l.id) LIVE_COUNT
from  INFO_TB_XXX b
join INFO_TB_XXXX_LIVE  l on  l.build_id = b.id and l.del_flag = '0' and l.LIVE_EDATE IS NULL
group by b.id

两段sql结果是一样的,
但是还不清楚第一段为啥那么慢?

  • 写回答

1条回答 默认 最新

  • threenewbee 2019-12-21 10:50
    关注

    第一个是先取迪卡尔集再where,效率是O(N^2)
    第二个join是直接用hash匹配,效率是O(LogN)
    所以随着数据量的增大,后者效率就会比前者高很多很多。

    评论

报告相同问题?

悬赏问题

  • ¥17 pro*C预编译“闪回查询”报错SCN不能识别
  • ¥15 微信会员卡接入微信支付商户号收款
  • ¥15 如何获取烟草零售终端数据
  • ¥15 数学建模招标中位数问题
  • ¥15 phython路径名过长报错 不知道什么问题
  • ¥15 深度学习中模型转换该怎么实现
  • ¥15 HLs设计手写数字识别程序编译通不过
  • ¥15 Stata外部命令安装问题求帮助!
  • ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
  • ¥15 TYPCE母转母,插入认方向