mysql标量子查询变成左连接_标量子查询优化外连接

同事发来2个语句,说语句1跑得慢,语句2很快就出结果。一执行,果然很慢。仔细发现,2个语句不等价。 语句1: select l.*,o.object_name from v$locked_object l left join all_objects o on l.object_id=o.object_id;语句2: select l.*,o.object_name from

同事发来2个语句,说语句1跑得慢,语句2很快就出结果。一执行,果然很慢。仔细发现,2个语句不等价。

语句1:

select l.*,o.object_name

from v$locked_object l left join all_objects o on l.object_id=o.object_id;

语句2:

select l.*,o.object_name

from v$locked_object l,all_objects o where l.object_id=o.object_id;

左外连接,少了一个加号,改一改语句2,使它等价为语句1.

语句3:

select l.*,o.object_name

from v$locked_object l,all_objects o where l.object_id=o.object_id(+);

改成等价后也非常慢。

虽然语句2不等价,为什么语句2要比1和3快?看了一会执行计划,明白了。语句1中OBJ$走的是全表,语句2中OBJ$走的是索引。

性能瓶颈主要是all_objects非常慢,count一下花了超过15分钟,有100w以上的数据。

最终返回数据量才80条。

标量子查询的优化方法有哪些?

一种是建立索引优化,一种是外连接。

那么是不是标量子查询任何时候性能都要比外连接差呢,不一定。

下面改成标量子查询的语句

语句4:

select l.*,(select o.object_name from all_objects o where l.object_id=o.object_id) from v$locked_object l;

现在这种情况本身有索引了,可以改写成标量子查询,也是非常快。

避免了OBJ$的全表,all_objects有100w多记录

改写后等价于原来左外连接的意思,速度杠杠的,2s内出结果。

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值