比如:
select t1.*
from table1 t1, table2 t2
where t1.col1 = t2.col2
和
select t1.*
from table1 t1inner join table2 t2 on t1.col1 = t2.col2
虽然运行结果是一样的,但是数据量大的情况下,发现inner join会快一些。大家都用哪种写法?
sql里的inner join和=等号有区别吗?
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
1条回答 默认 最新
threenewbee 2019-10-22 09:04关注结果一样,实现原理完全不同,join是基于hashtable连接比较,而=直接就是取笛卡尔集再过滤,所以后者效率低,是O(N^2),前者是O(LogN)
评论 打赏 举报解决 2无用