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 问题