说明

使用数据库为阿里云 云数据库RDS

错误日志:
1140 In aggregated query without GROUP BY 
expres ssion #1 of SELECT list contains
nonag gregated column 'a.customer_no'; thisis incom patible with sql_mode=only_full_group_by

日志翻译:
[Err]1140-在没有GROUP BY的聚合查询中,选择列表的表达式1包含非聚合列“a.customer_no”;这与sql“mode=only”full“GROUP”BY不兼容

原因

因为SQL中使用聚合函数,但未对查询数据进行分组处理,不满足 sql_mode【 语法校验规则 】

常用 sql_mod 数值

①ONLY_FULL_GROUP_BY
GROUP BY聚合分组,如果在SELECT中的列,没有在GROUP BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中;
如果使用聚合函数也应对数据进行分组
②NO_AUTO_VALUE_ON_ZERO
该值影响自增长列的插入。默认设置下,插入0或NULL代表生成下一个自增长值。如果用户希望插入的值为0,而该列又是自增长的,这个选项就回生效;
③STRICT_TRANS_TABLES
如果一个值不能插入到一个事务中,则中断当前的操作,对非事务表不做限制
④NO_ZERO_IN_DATE
不允许日期和月份为零
⑤NO_ZERO_DATE
mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告
⑥ERROR_FOR_DIVISION_BY_ZERO
在insert或update过程中,如果数据被零除,则产生错误而非警告。如果未给出该模式,那么数据被零除时Mysql返回NULL
⑦NO_AUTO_CREATE_USER
禁止GRANT创建密码为空的用户
⑧NO_ENGINE_SUBSTITUTION
如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常
⑨PIPES_AS_CONCAT
将"||"视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样是,也和字符串的拼接函数Concat想类似
⑩ANSI_QUOTES
不能用双引号来引用字符串,因为它被解释为识别符

解决方法

阿里云 云数据库RDS

1.登录RDS实例控制台,在上方选择地域,然后单击目标实例ID。
2.在左侧导航栏中单击参数设置。
3.找到sql_mode参数,单击sql_mode参数右侧运行参数值列的编辑按钮,将ONLY_FULL_GROUP_BY值删除。
4.单击提交参数,使修改的配置生效。如果未点击提交参数,修改数据不会生效
5.如果未生效,可等待一段时间或查看参数修改历史是否生效;也可尝试重启数据库

在这里插入图片描述

查询数据库中 sql_mode
select @@GLOBAL.sql_mode;
		或者
select @@SESSION.sql_mode;

执行Sql,不再出现该类提示

本地数据库(仅记录)

1. 查询mysql安装文件:whereis mysql
2. 编辑/etc/my.cnf 配置文件
		添加参数:
		sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
		(或者在上述 sql_mode 中自行进行选择配置
3. 重启mysql
service mysqld restart

4. 验收数据,查询数据库中 sql_mode

本地数据未进行操作,此处仅为记录

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐