杨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)
    所以随着数据量的增大,后者效率就会比前者高很多很多。

    评论

报告相同问题?

悬赏问题

  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制