mysql 5.7 解决 sql_mode=ONLY_FULL_GROUP_BY

Posted 陈江滨

tags:

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

试过很多百度的解决方法没有成功,觉得可能有些模糊,所以想写的详细些,方便少采坑。

登录数据库:

mysql -u root -pxxxxx

 

查询sql_mode包含哪些模块:

select @@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         

编辑 /etc/my.cnf

vim /etc/my.cof

在 [mysqld] 在下面添加:

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  service mysqld restart

 禁用ONLY_FULL_GROUP_BY前:

 

 禁用ONLY_FULL_GROUP_BY后:

 到此禁用 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”选项。

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默认ONLY_FULL_GROUP_BY语义介绍