MySQL报错:sql_mode=only_full_group_by解决方法
MySQL报错:sql_mode=only_full_group_by解决方法
登录mysql之后,执行命令查看当前的sql_mode配置
select @@global.sql_mode;
可以发现MySQL的sql_mode是开启了ONLY_FULL_GROUP_NY。
解决方法
把 sql_mode 中的 ONLY_FULL_GROUP_NY
去掉,其他不变即可。
找到MySQL的配置文件/etc/mysql/my.cnf
,在mysqld下添加如下配置即可。
#注意:这里一定要用上面自己查的,不要直接复制粘贴,否则mysql可能无法启动
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
说明:解释sql_mode的含义
(1)ONLY_FULL_GROUP_NY
含义:启用这个模式后,MySQL 在执行 GROUP BY 操作时,要求 SELECT 语句中的列必须是 GROUP BY 子句中的分组列或者包含在聚合函数中。换句话说,要求 SELECT 中的非聚合列必须在 GROUP BY 子句中出现。 作用:这个模式的作用是增强 SQL 查询语句的严格性,避免因数据未正确分组而导致结果不确定性的情况发生。通过强制要求所有非聚合列都在 GROUP BY 子句中列出,确保了查询结果的准确性和一致性
(2)STRICT_TRANS_TABLES
含义:当启用这个模式时,MySQL 会对事务中的数据插入和更新进行严格的类型检查,确保数据的准确性和完整性。 作用:在插入或更新数据时,如果发生类型不匹配或者值超出范围等问题,将会产生错误,确保了数据的一致性。
(3)NO_ZERO_IN_DATE
含义:禁止在日期中使用 '0000-00-00' 或 '0000-00-00 00:00:00' 这样的值。 作用:当启用这个模式时,MySQL 会禁止插入或更新日期字段为零值,以避免不合法的日期值的存储。
(4)NO_ZERO_DATE
含义:禁止在日期中使用 '0000-00-00' 这样的值。 作用:与 NO_ZERO_IN_DATE 类似,这个模式也是为了避免不合法的日期值的存储。
(5)ERROR_FOR_DIVISION_BY_ZERO
含义:当启用这个模式时,MySQL 在发生除零错误时将产生一个错误,而不是返回 NULL 或者一个警告。 作用:这个模式确保了在执行除法操作时,避免了由于除零而导致的意外结果,提高了数据计算的准确性。
(6)NO_ENGINE_SUBSTITUTION
含义:如果指定的存储引擎不可用,将不会自动替换为默认的存储引擎。 作用:这个模式要求所指定的存储引擎必须可用,如果不可用,则会产生错误,确保了使用正确的存储引擎。
引用来源
https://blog.csdn.net/m0_52985087/article/details/136232465