MySQL 5.7版本 sql_mode=only_full_group_by 问题

Posted 啥也不会的程序猿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL 5.7版本 sql_mode=only_full_group_by 问题相关的知识,希望对你有一定的参考价值。

具体错误:

SQLSTATE[42000]: Syntax error or access violation: 1055 Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column ‘库.表.字段‘ which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

查看:

查看 mysql 的 global.sql_mode

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

解决

修改 global.sql_mode

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 5.7版本 sql_mode=only_full_group_by 问题的主要内容,如果未能解决你的问题,请参考以下文章

MySQL 5.7版本sql_mode=only_full_group_by问题

mysql 5.7 或以上版本 group by 问题记录

mysql 5.7 解决 sql_mode=ONLY_FULL_GROUP_BY

GROUP BY不适用于MySQL 5.7,因为5.7使用SQL_MODE的“ONLY_FULL_GROUP_BY”选项。

MySQL 5.7默认ONLY_FULL_GROUP_BY语义介绍

MySQL sql_mode=only_full_group_by错误