mysql join和left join区别

mysql join原理:MySQL内部采用了一种叫做 nested loop join的算法。Nested Loop Join 实际上就是通过驱动表的结果集作为循环基础数据,然后一条一条的通过该结果集中的数据作为过滤条件到下一个表中查询数据,然后合并结果。如果还有第三个参与 Join,则再通过前两个表的 Join 结果集作为循环基础数据,再一次通过循环查询条件到第三个表中查询数据,如此往复,基本上MySQL采用的是最容易理解的算法来实现join。所以驱动表的选择非常重要,驱动表的数据小可以显著降低扫描的行数

left join 和 join 区别在于left join指定了驱动表,驱动表数据量对查询性能影响较大,而join是默认数据量最小的表为驱动表

上一篇:forkjoin分而治之的介绍和使用


下一篇:大数据之ClickHouse(下)