数据库
首页 > 数据库> > Mysql报错:1140 - In aggregated query without GROUP BY, expression #2 of SELECT list contains nonaggreg

Mysql报错:1140 - In aggregated query without GROUP BY, expression #2 of SELECT list contains nonaggreg

作者:互联网


经查阅资料得知,
在MySQL5.7版本之后对group by进行了优化。默认启动改进之后的版本启动了ONLY_FULL_GROUP_BY模式。

即ONLY_FULL_GROUP_BY是MySQL数据库提供的一个sql_mode,通过这个sql_mode来保证SQL语句“分组求最值”合法性的检查。这种模式采用了与Oracle、DB2等数据库的处理方式。即不允许select target list中出现语义不明确的列。

解决方式:
只要有聚合函数sum(),count(),max(),avg()等函数就需要用到group by

标签:1140,nonaggregated,GROUP,list,FULL,报错,mode,sql,group
来源: https://www.cnblogs.com/Arborblog/p/16353982.html