mysql两张大表join优化_MYSQL join 优化 --JOIN优化实践之快速匹配

本文探讨了如何优化MySQL中两张大表的JOIN操作,强调了在被驱动表上创建索引对于提升连接性能的重要性。通过左连接、右连接和内连接的实例,展示不同情况下合适的索引策略,以实现查询速度的显著提升。
摘要由CSDN通过智能技术生成

这篇博文讲述如何优化扫描速度。我们通过MySQL的JOIN(二):JOIN原理得知了两张表的JOIN操作就是不断从驱动表中取出记录,然后查找出被驱动表中与之匹配的记录并连接。这个过程的实质就是查询操作,想要优化查询操作,建索引是最常用的方式。那索引怎么建呢?我们来讨论下,首先插入测试数据。

48304ba5e6f9fe08f3fa1abda7d326ab.png

CREATE TABLE t1 (

id INT PRIMARY KEY AUTO_INCREMENT,

type INT

);

SELECT COUNT(*) FROM t1;

+----------+

| COUNT(*) |

+----------+

| 110000 |

+----------+

CREATE TABLE t2 (

id INT PRIMARY KEY AUTO_INCREMENT,

type INT

);

SELECT COUNT(*) FROM t2;

+----------+

| COUNT(*) |

+----------+

| 100 |

+----------+

48304ba5e6f9fe08f3fa1abda7d326ab.png

左连接

左连接中,左表是驱动表,右表是被驱动表。想要快速查找被驱动表中匹配的记录,所以我们可以在右表建索引,从而提高连接性能。

48304ba5e6f9fe08f3fa1abda7d326ab.png

-- 首先两个表都没建索引

EXPLAIN SELECT * FROM t1 LEFT JOIN t2 ON t1.type=t2.type;

+----+-------+------+------+--------+----------------------------------------------------+

| id | table | type | key | rows | Extra |

+----+-------+------+------+--------+----------------------------------------------------+

| 1 | t1 | ALL | NULL | 110428 | NULL |

| 1 | t2 | ALL | NULL | 100 | Using where; Usin

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值