mysql中group by优化

Posted ppjj

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql中group by优化相关的知识,希望对你有一定的参考价值。

如果需要对关联查询(inner join)做分组(group by),并且按照关联表(actor)中的某个列进行分组,那么通常采用关联表(actor)的标识列(actor_id)分组的效率比其他列更高:

select actor.first_name,actor.last_name,count(*) from film_actor inner join actor using(actor_id) group by actor.actor_id;

替换了

group by actor.first_name,actor.last_name

这个查询利用了演员的姓名(first_name和last_name)和actor_id直接相关的特点,但是不是所有的关联语句的查询都可以改写成select中直接使用非分组列(first_name,last_name)的形式的。甚至服务器设置sql_mode(ONLY_FULL_GROUP_BY)来禁止这样的写法。如果是这样,可以用min(),max()函数绕过这样的限制,但是一定要清楚,select后面出现的非分组列一定是直接依赖分组列,并且在每一个组内的值是唯一的,或者业务根本不在乎这个值具体是什么。

select min(actor.first_name),max(actor.last_name) .......

 

以上是关于mysql中group by优化的主要内容,如果未能解决你的问题,请参考以下文章

mysql GROUP BY、DISTINCT、ORDER BY语句优化

mysql sql优化之 优化GROUP BY 和 DISTINCT

MySQL 查询优化与 group by 和 order by rand

MySQL的SQL语句优化-group by语句的优化

Mysql group by,order by,dinstict优化

Mysql之order by|group by 排序优化