Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column
环境MySQL:8+在执行类似这样的语句时:SELECT * from template_detail a group by template_id;然后报错了:1055 - Expression #1 of SELECT list is not in GROUP BY clause and containsnonaggregated column 'ssm.template_detail.id'
环境
MySQL:8+
在执行类似这样的语句时:
SELECT * from template_detail a group by template_id;
然后报错了:
1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains
nonaggregated column 'ssm.template_detail.id' which is not functionally dependent on columns in GROUP BY clause;
this is incompatible with sql_mode=only_full_group_by, Time: 0.0000
具体原因是:
ONLY_FULL_GROUP_BY: 对于GROUP BY聚合操作,如果在SELECT中的列,没有在GROUP
BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中
也就是说,select 后面的字段应该是group 中出现的:
SELECT template_id from template_detail a group by template_id;
这样就成功了。
但是实际情况下,我们肯定不是只获取到这么一个字段,需要获取多个,那么该如何解决呢?
修改配置的方法
方法一
执行下面的语句
select @@global.sql_mode
得到:
ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
去掉ONLY_FULL_GROUP_BY,重新设置值。
set @@global.sql_mode
='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
本人实践:无论是重启MySQL,还是不重启MySQL,都不行。
方法二
sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
执行完成后,然后再执行上面的语句,发现成功了。(不用重启MySQL,猜测,如果真的重启MySQL,配置肯定会被还原,所以别重启)。
方法三
MySQL
有any_value(field)
函数,他主要的作用就是抑制ONLY_FULL_GROUP_BY
值被拒绝
官方有介绍,地址:https://dev.mysql.com/doc/refman/5.7/en/miscellaneous-functions.html#function_any-value
我们可以把select
语句中查询的属性(除聚合函数所需的参数外),全部放入any_value(field)函数中;
例如:
SELECT a.template_id,any_value(a.detail) detail, any_value(a.id) id
from template_detail a
group by template_id
这样sql
语句不管是在ONLY_FULL_GROUP_BY
模式关闭状态还是在开启模式都可以正常执行,不被mysql
拒绝。
从上面的语句中也能看出来,每个显示的字段都要写any_value(...)
,这样其实很麻烦。
个人偏向修改配置吗,一次性解决的那种,只是方法一,我自己没有测试出来,本地环境,用方法二也可以。
sql_mode说明
ONLY_FULL_GROUP_BY: 对于GROUP BY聚合操作,如果在SELECT中的列,没有在GROUP
BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中
NO_AUTO_VALUE_ON_ZERO: 该值影响自增长列的插入。默认设置下,插入0或NULL代表生成下一个自增长值。如果用户
希望插入的值为0,而该列又是自增长的,那么这个选项就有用了。
STRICT_TRANS_TABLES: 在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制
NO_ZERO_IN_DATE: 在严格模式下,不允许日期和月份为零
NO_ZERO_DATE: 设置该值,mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告。
ERROR_FOR_DIVISION_BY_ZERO: 在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。如
果未给出该模式,那么数据被零除时MySQL返回NULL
NO_AUTO_CREATE_USER: 禁止GRANT创建密码为空的用户
NO_ENGINE_SUBSTITUTION:
如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常
PIPES_AS_CONCAT:
将”||”视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样的,也和字符串的拼接函数Concat相类似
ANSI_QUOTES: 启用ANSI_QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符
参考地址:
SELECT list is not in GROUP BY clause and contains nonaggregated column
https://blog.csdn.net/lxw1844912514/article/details/100975571
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)