坑人的Mysql5.7 (默认不支持Group By语句)(转)

部署项目时,项目启动完毕。点击有group by 查询语句时出现错误,界面中没有该有的数据。查询log日志发现错误mysql

 Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'database_tl.emp.id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by 。。。。sql

因为以前也没有记录,因此日志信息在网上找了一个大体同样的。this

缘由:spa

mysql 5.7 新特性:点击打开连接 默认是不支持GroupBy 语句的。命令行

能够进入mysql 命令行中使用日志

mysql> SELECT @@GLOBAL.sql_mode;

进行查询code

结果为:blog

+-------------------------------------------------------------------------------------------------------------------------------------------+
| @@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 |
+-------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
因此咱们须要作的就是将上面画红的属性注掉。

这里为了以后全局,重启以后也能生效,使用修改配置文件进行修改属性部署

(1)将这个 @@GLOBAL.sql_mode 设置为空it

mysql> set @@GLOBAL.sql_mode='';
Query OK, 0 rows affected, 1 warning (0.00 sec)

(2)打开配置文件,这里mysql5.7 的配置文件很诡异,这里个人配置文件的路径为:/etc/mysql/mysql.conf.d 下的mysqld.cnf

打开找到[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

这样,以前项目中groupby 语句就能够使用了

相关文章
相关标签/搜索