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 解决 sql_mode=ONLY_FULL_GROUP_BY
GROUP BY不适用于MySQL 5.7,因为5.7使用SQL_MODE的“ONLY_FULL_GROUP_BY”选项。