首页 > 数据库 >MySQL优化之group by

MySQL优化之group by

时间:2023-07-21 17:55:44浏览次数:32  
标签:group tb age profession 分组 user MySQL 优化

MySQL之group by

group by优化

 #删除掉目前的联合索引 idx_user_pro_age_sta
 drop index idx_user_ro_age_sta on tb_user;
 #执行分组操作,根据profession字段分组
 explain select profession , count(*) from tb_user group by profession;
 #创建索引
 Create index idx_user_pro_age_sta on tb_user(profession , age , status);
 #执行分组操作,根据profession字段分组explain select profession , count(*) from tb_user group by profession;
 #执行分组操作,根据profession字段分组explain select profession , count(*) from tb_user group by profession, age;




  1. 在分组操作时,可以通过索引来提高效率。

  2. 分组操作时,索引的使用也是满足最左前缀法则的。

标签:group,tb,age,profession,分组,user,MySQL,优化
From: https://www.cnblogs.com/liandaozhanshi/p/17572091.html

相关文章

  • MySQL之order by优化
    MySQL之orderby优化.Usingfilesort:通过表的索引或全表扫描,读取满足条件的数据行,然后在排序缓冲区sortbuffer中完成排序操作,所有不是通过索引直接返回排序结果的排序都叫FileSot排序。Usingindex:通过有序索引顺序扫描直接返回有序数据,这种情况即为usingindex,不需要......
  • MySQL之插入优化
    MySQL之插入优化insert优化原批量插入:insertintotb_testvalues(1,'tom');insertintotb_testvalues(2,'cat');insertintotb_testvalues(3,'jerry');改批量插入:insertintotb_testvalues(1,'Tom'),(2,'Cat'),(3,'Jer......
  • Mysql 命令行方式导出数据文件
    概述Linux服务器上有一个数据库表包含大于50亿条的记录,通过Navicat等数据迁移工具,将数据迁移到另一个服务器相同表中,总是执行一段时间后卡死,故选择先导出数据文件,再去另一个服务器导入该文件。可以使用Navicat导出数据文件,也可以使用MySQL支持的命令导出数据文件。本文章介绍如何使......
  • 递归优化策略(数组存储)
    优化原因:有重复计算解决方案:用数组记录下一些会重复用到的数据,方便直接调用eg(虽然此题不适用)longlongpell(intm){if(m==1){return1;}elseif(m==2){return2;}elseif(a[m]!=0)//判断是否算过{returna[m];//算过的话直接调......
  • 索引的优化
    如下一.索引的优化1.在经常查询而不经常增删改的操作的字段加索引。2.Orderby和groupby后面的字段应该是索引字段。3.索引字段长度不应该很长。二.会导致索引丢失,在开发中尽量避免出现1.where子句中使用like关键字时,前置百分号会导致索引失效。2.where子句中使用is......
  • mysql id自增默认值
    MySQLID自增默认值在MySQL中,我们经常会使用自增的ID作为表的主键,以确保每个记录都有一个唯一的标识符。MySQL提供了一种方式来自动为这些ID生成唯一的值,即使用自增默认值。本文将介绍MySQL中的自增默认值的使用方法,并提供一些代码示例。什么是自增默认值自增默认值是一种特殊的......
  • mysql host 多个
    MySQL主机多个的使用方法MySQL是一种开源的关系型数据库管理系统,被广泛应用于各种Web应用程序中。在某些情况下,我们可能需要连接多个MySQL主机,这种情况下可以使用多个主机来提高应用程序的性能、可用性和可扩展性。本文将介绍如何在应用程序中使用多个MySQL主机。为什么使用多个M......
  • MySql 终端常用指令
    1、开发环境:Window10+mysql-8.0.33-win642、管理员模式打开终端3、登录数据库(停止+开启+登录),具体指令参考MySql安装篇 4、操作数据库相关功能1)查看数据库列表:showdatabases;主要用于显示当前存在的数据库2)创建数据库:createdatabasedb_dev;其......
  • 使用prometheus+grafana监控Linux和Mysql
    整个监控系统分为三部分:prometheus,grafana,xxxx_exporter(各种类型的数据采集器,在本例中就是node_exporter,mysqld_exporter)1、在主监控服务器上安装prometheus作为主服务2、在主监控服务器上安装grafana用于界面展示3、在需要监控的服务器安装xxxx_exporter用于采集数据并提供......
  • mysql 根据in 传参排序
    MySQL根据IN传参排序在MySQL中,我们经常需要根据给定的一组值来进行排序操作。而IN关键字正是用来筛选出一组指定值的数据。本文将详细介绍如何在MySQL中使用IN传参进行排序。什么是IN关键字IN关键字是MySQL中的一个操作符,用于指定一个值是否在一个指定的范围内。其基本语法如下:......