原标题:MySQL 在 INNER JOIN 场景的使用-爱可生
本文详细介绍了 MySQL 参数 join_buffer_size 在 INNER JOIN 场景的使用,OUTER JOIN 不包含。在讨论这个 BUFFER 之前,我们先了解下 MySQL 的 INNER JOIN 分类。
如果按照检索的性能方式来细分,那么无论是两表 INNER JOIN 还是多表 INNER JOIN,都大致可以分为以下几类:
1. JOIN KEY 有索引,主键
2. JOIN KEY 有索引,二级索引
3. JOIN KEY 无索引
今天主要针对第三种场景来分析,也是就全表扫的场景。
回过头来看看什么是 join_buffer_size?
JOIN BUFFER 是 MySQL 用来缓存以上第二、第三这两类 JOIN 检索的一个 BUFFER 内存区域块。一般建议设置一个很小的 GLOBAL 值,完了在 SESSION 或者 QUERY 的基础上来做一个合适的调整。
比如,默认的值为 512K, 想要临时调整为 1G。那么,
mysql>set session join_buffer_size = 1024 * 1024 * 1024;
mysql>select * from ...;
mysql>set session join_buffer_size=default;
或者
mysql>select /*+ set_var(join_buffer_size=1G) */ * from ...;
接下来详细看下 JOIN BUFFER 的用法。
那么 MySQL 里针对 INNER JOIN 大致有以下几种算法,
1. Nested-Loop Join 翻译过来就是嵌套循环连接,简称 NLJ。
这种是 MySQL 里最简单、最容易理解的表关联算法。
比如,拿语句 select * from p1 join p2 using(r1) 来说,
先从表 p1 里拿出来一条记录 ROW1,完了再用 ROW1 遍历表 p2 里的每一条记录,并且字段 r1 来做匹配是否相同,以便输出;再次循环刚才的过