MySQL 原理与优化,Group By 优化 技巧

发布于:2022-08-08 ⋅ 阅读:(265) ⋅ 点赞:(0)
149ac69a0bd3b865f1078b4d3c6fee8a.jpeg

今天来看看MySQL 中如何多Group By 语句进行优化的。

先创建tb_user 表如下


2cbcbb703366a900c322bf75556a31c6.jpeg

通过show index from tb_user; 命令查看表,没有存在任何的索引。


d79184d36d04fcd5f4a30f57f3c7e07f.jpeg

执行如下代码,查看SQL 执行情况

explain select profession, count(*) from tb_user group by profession ;

8b8cc1ac4193a93bd12cc2b3a9db76b4.jpeg

发现返回结果中 type 为“ALL” ,Extra 返回“Using temporary” 说明没有使用索引。

于是,创建基于profession,age和status 的索引如下

create index index_user_pro_age_sta on tb_user(profession ,age, status);

这里创建索引从左到右的顺序是 profession ,age, status。

此时再次执行SQL执行计划如下:

explain select profession, count(*) from tb_user group by profession ;


87623ffe52dff28f0badb4c2f9dcc3f3.jpeg


发现使用了索引“index_user_pro_age_sta”。说明在执行 group by操作的时候,使用联合索引是有效的。

接着在看使用如下代码:

explain select age, count(*) from tb_user group by age;

SQL 语句使用age 进行group by,查看explain的结果如下:


fe4f79237367ea03c3ce74dbfca36683.jpeg

在Extra 字段中发现使用了“Using temporary”,说明没有走索引,是因为没有满足索引的最左前缀法则

联合索引 index_user_pro_age_sta的顺序从左到右分别是 profession ,age, status。

上面的SQL 语句Group by 后面接着的是age ,因此出现“Using temporary”。

这里对SQL 进行修改。如下:

explain select profession,age, count(*) from tb_user group by profession, age;


18bccb7a47c8f0e5ca835b2e72e398e3.jpeg

由于group by 后面跟着profession, age ,符合联合索引的创建顺序,因此索引生效。

我们再来试试再加入过滤条件的情况,加入profession = 软件工程,此时group by 里面只显示 age,那么此时是否会走索引, 答案是 using index。因为满足了最左前缀法则。

explain select age, count(*) from tb_user where profession = '软件工程' group by age;


b8f26bd08e1e596f919beeb553877920.jpeg


总结一下:

SQL在分组操作的时候,可以通过索引来提高效率。

做分组操作的时候,索引的使用需要满足最左前缀法则。

本文含有隐藏内容,请 开通VIP 后查看

网站公告

今日签到

点亮在社区的每一天
去签到