执行sql报错only_full_group_by的2种解决方法!
执行sql报错only_full_group_by的2种解决方法!
一、前言
最近老项目换新数据库(都是mysql),有些在老数据库可以执行的sql,在新数据库执行就会报错,如下:
1
2
3
4
5
6
7
8
|
[SQL] SELECT * FROM bsc_user_t A group by user_name limit 100 [Err] 1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'otp.A.id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by |
意思是说数据库的模式是sql_mode=only_full_group_by
,group by的字段必须和查询字段一致才行,否则不让执行,例如:
1
2
3
4
5
6
|
SELECT user_name FROM bsc_user_t A group by user_name limit 100 |
但是这样不太能符合原本需要的功能,而且老项目有很多这样的不标准语句,都改不现实。
二、解决方法
修改数据库配置。搜到2种方法:
1.临时关闭only_full_group_by模式
(1)先查看自己的数据库是怎么配置的:
1
2
3
|
show VARIABLES LIKE '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 |
(2)然后,把ONLY_FULL_GROUP_BY
去掉,再设置下:
1
|
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' ; |
(3)注意这种方法,重启mysql后会失效
2.永久关闭only_full_group_by模式
(1) 找到配置文件/etc/my.cnf(或则关联文件夹找到mysql-server.cnf)
(2) 找到当前配置的sql_mode
那行,去掉ONLY_FULL_GROUP_BY
;
如果没有,就在文件内的[mysqld]
后增加配置:
1
|
sql_mode= 'STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION' |
(3)保存配置文件后,重启Mysql。
三、备注
本人执行
1
|
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' ; |
报错了:
[Err] 1227 - Access denied; you need (at least one of) the SUPER privilege(s) for this operation
说明当前用户没有权限;需要联系管理员执行才行;
改服务器配置也同理,如果没有权限,联系管理员。
学习资料见知识星球。
以上就是今天要分享的技巧,你学会了吗?若有什么问题,欢迎在下方留言。
快来试试吧,小琥 my21ke007。获取 1000个免费 Excel模板福利!
更多技巧, www.excelbook.cn
欢迎 加入 零售创新 知识星球,知识星球主要以数据分析、报告分享、数据工具讨论为主;
1、价值上万元的专业的PPT报告模板。
2、专业案例分析和解读笔记。
3、实用的Excel、Word、PPT技巧。
4、VIP讨论群,共享资源。
5、优惠的会员商品。
6、一次付费只需99元,即可下载本站文章涉及的文件和软件。
共有 0 条评论