这两种SQL语句写法有何不同,哪种效率高?

phuson 2014-02-11 09:52:17
1、
select *
from A join B on A.id=B.id
where A其他条件 and B其他条件

2、
select *
from A,B
where A.id=B.id
and A其他条件 and B其他条件

这两种写法有什么区别?
...全文
391 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
wushangjimo 2014-02-12
  • 打赏
  • 举报
回复
我刚才在本地测试了一下,11g的,两种方式完全一样,连解释计划都一样
shenlele088 2014-02-12
  • 打赏
  • 举报
回复
不知道是习惯还是什么,1看着就不爽
sducaicai 2014-02-11
  • 打赏
  • 举报
回复
尽量使用Join 而不是Where来列出关联条件,特别是多个表联合的时候。 原因是: 1)在效率上,Where可能具有和Inner join一样的效率。但基本可以肯定的是Join的效率不比Where差。 (2)使用Join可以帮助检查语句中的无效或者误写的关联条件
流浪川 2014-02-11
  • 打赏
  • 举报
回复
引用 3 楼 phuson 的回复:
实际使用中,我感觉好像第二种执行快些,不知怎么回事。
你看看是不是其他条件影响的,查一下具体的执行计划。
phuson 2014-02-11
  • 打赏
  • 举报
回复
实际使用中,我感觉好像第二种执行快些,不知怎么回事。
流浪川 2014-02-11
  • 打赏
  • 举报
回复
从关联角度看效率是一样的,不过加上其他条件的时候就要具体分析了。
流浪川 2014-02-11
  • 打赏
  • 举报
回复
没有区别,执行计划应该也是一样的。
-江沐风- 2014-02-11
  • 打赏
  • 举报
回复
建议使用1而不是2; 可以看一下执行计划:explain一下;

17,382

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 基础和管理
社区管理员
  • 基础和管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧