oracle 的left join和(+)真的可以起到一样的效果吗?
发布日期:2021-06-28 19:49:13 浏览次数:3 分类:技术文章

本文共 515 字,大约阅读时间需要 1 分钟。



select * from a,b where a.id=b.id(+);    --左连接,a表为主     from tableA, tableB where a.xx=b.xx(+)

select * from a left join b on a.id=b.id;  --   tableA left join tableB on a.xxx=b.xxx

很多资料说上面两个语句的效果是一样的,实际上今天经过测试发现两者的执行计划大不相同(查询结果是一样的);

至于为什么会这样,暂时没有深究,手头的一个例子表明按照第一种写法的效率会高,

或许其他的例子结果不一样,等有时间的时候再测试一下吧.

这个比较细微,我尽量回答。

总的来说,2种写法,在oracle 里,效率和性能区别不大。
如果非要比较的话,大概有以下区别:
(+) 和 left join ,在检索显示的字段很少的时候,或者干脆就是检索count(*)的时候,

在效率和性能上,是一样,甚至cpucost都完全一样;

但是在检索显示的字段比较多得时候,执行,left join 比(+)的效率高;

当然,执行第二次之后,由于数据已经到了缓存,区别也不明显了,基本是一致的。

转载地址:https://blog.csdn.net/xxxcyzyy/article/details/47314609 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:10004--SpringMVC @PathVariable 映射 URL 绑定的占位符 /{xxx}
下一篇:10009--Java自定义注解 Annotation详解

发表评论

最新留言

初次前来,多多关照!
[***.217.46.12]2024年04月14日 01时18分57秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章