sql_mode中的ONLY_FULL_GROUP_BY的作用

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: MySQL 8中的sql_mode中的默认值如下

MySQL 8中的sql_mode中的默认值如下:


mysql> select @@sql_mode\G
*************************** 1. row ***************************
@@sql_mode: ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
1 row in set (0.00 sec)

sql_mode的配置中ONLY_FULL_GROUP_BY是开发人员最容易遇到坑,这个设置对SQL语句的要求是:出现在select字段后面的只能是group by后面的分组字段,或使用聚合函数包裹着的字段。

例如下面的SQL语句在select的字段中增加了一个不是group by后的字段后将出错:


mysql> select staff_id , max(amount) from payment group by staff_id;
+----------+-------------+
| staff_id | max(amount) |
+----------+-------------+
|        1 |       11.99 |
|        2 |       11.99 |
+----------+-------------+
2 rows in set (0.04 sec)
mysql> select rental_id, staff_id , max(amount) from payment group by staff_id;
ERROR 1055 (42000): Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'sakila.payment.rental_id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
mysql>


遇到这种错误可以修改SQL语句解决,也可以修改sql_mode,去掉其中的ONLY_FULL_GROUP_BY,例如:


mysql> select @@sql_mode;
+------------+
| @@sql_mode |
+------------+
|            |
+------------+
1 row in set (0.00 sec)
mysql>  select rental_id, staff_id , max(amount) from payment group by staff_id;
+-----------+----------+-------------+
| rental_id | staff_id | max(amount) |
+-----------+----------+-------------+
|        76 |        1 |       11.99 |
|      1422 |        2 |       11.99 |
+-----------+----------+-------------+
2 rows in set (0.19 sec)
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
28天前
|
SQL 存储 Oracle
SQL,Group By 真扎心,原来是这样
SQL,Group By 真扎心,原来是这样
37 0
|
7月前
|
关系型数据库 MySQL
报错sql_mode=only_full_group_by
报错sql_mode=only_full_group_by
|
9月前
|
SQL 关系型数据库 MySQL
【已解决】Mysql8.0及以上 only_full_group_by以及其他关于sql_mode原因报错详细解决方案
【已解决】Mysql8.0及以上 only_full_group_by以及其他关于sql_mode原因报错详细解决方案
1064 0
|
11月前
|
SQL 数据库 数据库管理
sql数据定义语句(cascade,set,null,no action的区别)
sql数据定义语句(cascade,set,null,no action的区别)
232 0
|
SQL
sql group
sql group
87 0
|
SQL 关系型数据库 MySQL
MySQL中出现sql_mode=only_full_group_by问题解决
在 MySQL 5.7 以上的版本中 sql_mode 新加入了 only_full_group_by,导致我们在使用 group by 函数的时候,则会报错
239 0
MySQL中出现sql_mode=only_full_group_by问题解决
|
关系型数据库 MySQL
MySQL:报错 ERROR 1055 (42000)sql_mode=only_full_group_by
MySQL:报错 ERROR 1055 (42000)sql_mode=only_full_group_by
190 0
|
SQL 关系型数据库 MySQL
Mysql异常'SET OPTION SQL_SELECT_LIMIT=DEFAULT'
在用hive时遇到这样的一个异常,因为hive的元数据是存储在mysql数据库中,所以对于hive表的操作相应的会操作数据库中表的数据,该问题发生于删除表的时候,创建的时候并未产生该异常。经过查阅资料了解到mysql通过jdbc链接的时候会进行测试'SET OPTION SQL_SELECT_LIMIT=DEFAULT',但是5.6以后的版本弃用了set的方式。
3747 0
|
SQL
SQL中GROUP BY用法示例
概述 GROUP BY我们可以先从字面上来理解,GROUP表示分组,BY后面写字段名,就表示根据哪个字段进行分组,如果有用Excel比较多的话,GROUP BY比较类似Excel里面的透视表。
1056 0
|
SQL
SQL|为什么需要GROUP BY
我们拥有下面这个 "Orders" 表: image.png 现在,我们希望查找每个客户所有订单的总金额。怎么做? 分析思路 1、找出每个客户的每笔订单并根据客户进行分组。
977 0