[MySQL] group by 聚合函数的原理和聚合限制原因SELECT list is not in GROUP BY clause and contains nonaggregated column

group by 的原理是 

先把数据根据分组字段 , 分好组 ,

然后再每个分组里面执行具体的聚合操作

 

ONLY_FULL_GROUP_BY模式的限制是:

SELECT list is not in GROUP BY clause and contains nonaggregated column

select查询的列里面 , 有不是group by子句中的字段 , 有不是聚合函数的字段

 

原因是:

group by后 , 所有的字段和属性 , 都是这个分组的属性了

一个小组的属性里 , 只有知道 最大 / 最小 / 平均 /  总数  , 这样的聚合属性才是有意义的

每个组员个体的属性是没有意义的 

因此才会出现这个限制

 

posted @ 2021-04-26 11:24  唯一客服系统开发笔记  阅读(559)  评论(0编辑  收藏  举报