sql_mode=only_full_group_by怎么设置
时间: 2024-09-06 10:03:48 浏览: 55
SQL的`sql_mode=only_full_group_by`是一个MySQL服务器配置选项,它控制了SQL的处理方式,特别是如何处理GROUP BY子句和SELECT列表的关系。默认情况下,如果设置了`only_full_group_by`,那么除了出现在GROUP BY子句中的列以外,查询中的非聚合列(即那些未被COUNT()、SUM()等聚合函数修饰的列)不允许直接出现在SELECT列表中。
如果你想更改这个设置,通常是在MySQL服务器启动时通过`my.cnf`文件或者在命令行中使用`SET`命令来进行。以下是设置示例:
- 在`my.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,only_full_group_by"
```
- 在数据库客户端启动时:
```sql
SET GLOBAL sql_mode = 'only_full_group_by';
```
记得重启MySQL服务使更改生效。
如果你不想启用这个模式,可以将其删除或者设置为NULL或空字符串,恢复到更宽松的处理方式:
```sql
SET GLOBAL sql_mode = '';
```
相关问题
怎样设置 sql_mode=only_full_group_by
根据引用[2]的解释,sql_mode=only_full_group_by在MySQL 5.7.5之前默认是不启用的,因此如果需要启用该功能,需要手动设置sql_mode参数。具体步骤如下:
1. 打开MySQL配置文件my.cnf(Windows下为my.ini),在[mysqld]下添加以下内容:
```
[mysqld]
sql_mode=only_full_group_by
```
2. 重启MySQL服务,使配置生效。
如果只是临时需要启用该功能,可以在MySQL客户端中执行以下命令:
```
SET sql_mode='only_full_group_by';
```
如果需要关闭该功能,可以将sql_mode参数设置为空,或者在MySQL客户端中执行以下命令:
```
SET sql_mode='';
```
sql_mode=only_full_group_by
在MySQL 5.7版本后,默认开启了SQL_MODE严格模式,其中一个选项是sql_mode=only_full_group_by。这个模式要求在进行group by聚合操作时,select语句中的列只能是出现在group by中的列或者使用聚合函数(如max()、min()等)。如果不符合这个规则,就会报错。
为了解决这个问题,你可以按照下面的方法进行操作:
1. 在MySQL配置文件中的[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'。这样可以将sql_mode的设置更改为允许使用所有的模式,包括only_full_group_by。
2. 修改你的SQL语句,确保select中的列要么是出现在group by中的列,要么是使用了聚合函数。例如,你可以修改你的SQL语句为:select uid from user_order group by uid; 这样就不会再报错了。
3. 如果你不想修改MySQL的全局配置,你可以在每个需要执行的SQL语句前加上SET sql_mode='';来临时关闭严格模式。这样在执行完这个语句后,严格模式就会恢复。但这种方法并不推荐,因为可能会导致其他的潜在问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [MySQL提示sql_mode=only_full_group_by解决办法](https://blog.csdn.net/M__L__/article/details/126806559)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
阅读全文