一文读懂GROUP BY 1,2 VS GROUP BY column_1, column_2 的区别

为了更直观的查看这两者的区别,我把示例表格输入本地 MySQL 客户端里,并用 EXPLAIN 进行执行效率的分析。 以下是分别得到的 EXPLAIN 分析结果:

简单解释一下这个表格里面的一些重要字段含义:

● select_type:表示查询的类型,常见的类型有 SIMPLE、PRIMARY、SUBQUERY、DERIVED 等。SIMPLE 表示简单查询,PRIMARY 表示主查询,SUBQUERY 表示子查询,DERIVED 表示派生表的查询。

● type:表示连接类型,包括 system、const、eq_ref、ref、range、index、all 等。一般来说,连接类型从最好到最差的顺序是 system、const、eq_ref、ref、range、index、all。

● key:表示实际选择的索引。

● ref:表示连接使用的索引或常数。

● rows:表示估计要检查的行数。

其中最值得关注的是 type 字段,因为它描述了 MySQL 在执行查询时使用的连接算法,是能影响了查询性能的最直观表现。而 ALL表示全表扫描 ,没使用索引,对所有行进行扫描。回到此题,两种查询语句的返回字段值都是一样的,所以如果仅在示例表给出的数据上执行这两种查询,其实是 没区别的。

但是,小白为了更加严谨一点,因为此题仅 7 条数据,所以当表格数据量达到 10 万甚至更大的时候,这两种查询是否还是没区别?

为了验证我的想法,我先用存储过程写了一个自动生成类似数据的过程,且数据量达到了 10 万条左右。

相关推荐
8Qi84 小时前
回文子串(Palindromic Substrings)—— 题解
算法·leetcode·职场和发展·动态规划
小宋加油啊9 小时前
机械臂抓取物体 PVN3D算法调研学习
学习·算法·3d
lqqjuly9 小时前
前沿算法深度解析(一)
算法
小欣加油9 小时前
leetcode1926 迷宫中离入口最近的出口
数据结构·c++·算法·leetcode·职场和发展
happymaker062612 小时前
LeetCodeHot100——42.接雨水
算法
阿正的梦工坊12 小时前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
八解毒剂14 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
运行时记录14 小时前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
啦啦啦啦啦zzzz14 小时前
算法总结(二分查找、双指针)
c++·算法