[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后 , 所有的字段和属性 , 都是这个分组的属性了

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

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

因此才会出现这个限制

 

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

上一篇:图(有向图,无向图)的邻接矩阵表示C++实现(遍历,拓扑排序,最短路径,最小生成树) Implement of digraph and undigraph using adjacency matrix


下一篇:C++中基于形参是否为引用的重载(奇怪的重载)