MySQL 原理优化之Group By的优化技巧

 更新时间:2022年08月14日 10:43:35   作者:51CTO崔皓​​​​​​​  
这篇文章主要介绍了MySQL 原理优化之Group By的优化技巧,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下

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

先创建tb_user 表如下:

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

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

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

发现返回结果中 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 ;

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

接着在看使用如下代码:

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

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

在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;

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

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

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

总结一下:

SQL在分组操作的时候,可以通过索引来提高效率。做分组操作的时候,索引的使用需要满足最左前缀法则。

到此这篇关于MySQL 原理优化之Group By的优化技巧的文章就介绍到这了,更多相关MySQLGroup By优化内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mysql系列SQL查询语句书写顺序及执行顺序详解

    Mysql系列SQL查询语句书写顺序及执行顺序详解

    这篇文章主要为大家介绍了Mysql系列SQL查询语句的书写顺序及执行顺序示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2021-10-10
  • Mysql开启外网访问的全过程记录

    Mysql开启外网访问的全过程记录

    mysql 默认是不允许外放访问的,只允许 localhost 或 127.0.0.1 访问,下面这篇文章主要给大家介绍了关于Mysql开启外网访问的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-05-05
  • MySQL最新版8.1.0版本部署和新特性详解

    MySQL最新版8.1.0版本部署和新特性详解

    MySQL8.1的应该来说是8.0版本的bug修复,这是 MySQL 变更发版模型后的第一个创新版本,本文给大家介绍了MySQL最新版8.1.0版本部署和新特性,需要的朋友可以参考下
    2023-11-11
  • 开启MySQL远程连接的方法

    开启MySQL远程连接的方法

    这篇文章主要介绍了开启MySQL远程连接的方法,帮助大家更好的理解和学习MySQL数据库的使用,感兴趣的朋友可以了解下
    2020-12-12
  • MySQL时间盲注的五种延时方法实现

    MySQL时间盲注的五种延时方法实现

    MySQL时间盲注主要有五种,sleep(),benchmark(t,exp),笛卡尔积,GET_LOCK() RLIKE正则,本文就主要介绍了这五种方法,感兴趣的可以了解一下
    2021-05-05
  • mysql5.6.8源码安装过程

    mysql5.6.8源码安装过程

    这篇文章主要介绍了mysql5.6.8源码安装过程,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-01-01
  • MySQL中实现动态表单中JSON元素精准匹配的方法示例

    MySQL中实现动态表单中JSON元素精准匹配的方法示例

    本文主要介绍了MySQL中实现动态表单中JSON元素精准匹配的方法示例,重点讲解如何在将设计好的动态表单信息进行提取,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • MYSQL主从库不同步故障一例解决方法

    MYSQL主从库不同步故障一例解决方法

    第一次做完主从库同步后正常,但工作过程中发现有一个库的数据库没有同步起来,在另外一个mysql(3307)中
    2010-06-06
  • web方式的mysql管理工具详解

    web方式的mysql管理工具详解

    这篇文章主要介绍了web方式的mysql管理工具,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • MySQL数据库远程访问权限如何打开(两种方法)

    MySQL数据库远程访问权限如何打开(两种方法)

    本文通过两种方法给大家介绍MySQL数据库远程访问权限的打开方法,非常不错,实用性非常高,感兴趣的朋友一起看看吧
    2016-05-05

最新评论