Mysql数据库错误提示信息 [ERRO-1140 sql_mode=only_full_group_by ]
Mysql[Erroe-1140]说明原因解决方法阿里云 云数据库RDS本地数据库(仅记录)说明使用数据库为阿里云 云数据库RDS错误日志:1140 In aggregated query without GROUP BYexpres ssion #1 of SELECT list containsnonag gregated column 'a.customer_no'; thisis inco
·
Mysql[Erroe-1140]
说明
使用数据库为阿里云 云数据库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
本地数据未进行操作,此处仅为记录
更多推荐
所有评论(0)