sql-mode去掉了only_full_group_by不生效依然报错
时间: 2023-10-15 21:25:34 浏览: 49
您好!对于SQL模式中的 `ONLY_FULL_GROUP_BY`,它是在MySQL 5.7版本引入的一种严格模式,用于确保`GROUP BY`语句中的列都包含在聚合函数中。如果您在MySQL 5.7版本以后的版本中遇到了该报错,可能有以下几种原因:
1. SQL模式未正确修改:请确保您已经修改了MySQL的全局配置文件(例如my.cnf或my.ini),并在[mysqld]部分添加了`sql-mode`参数。
2. 修改不生效:有些MySQL版本可能在其他配置文件中或启动脚本中设置了`sql-mode`参数,您需要检查这些文件并确保修改生效。
3. 动态设置被覆盖:如果您在MySQL命令行或客户端中使用`SET`语句修改了`sql_mode`参数,但没有永久保存到配置文件中,则重启MySQL服务器后会恢复默认设置。
4. 其他因素:有时候报错可能与其他SQL查询或表结构有关。请确认您的GROUP BY语句是否符合语法规则,并且没有其他引起报错的因素。
为了更详细地排查问题,我建议您提供更多的信息,例如具体的报错信息、MySQL版本、相关的SQL查询语句等。这样我可以更好地帮助您解决这个问题。
相关问题
怎样设置 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 8.0
在MySQL 8.0中,sql_mode=only_full_group_by是一种SQL模式,它使得在执行GROUP BY时,SELECT列表中的非聚合列必须出现在GROUP BY子句中。这是为了确保查询结果的准确性和一致性。然而,这也可能导致一些查询出错,例如在SELECT列表中包含了非聚合列并且没有在GROUP BY子句中列出。引用
要解决这个问题,有两种方法可以尝试。首先,你可以修改全局设置,这样对于新建的数据库会有效。你可以执行以下命令:SET @@global.sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'; 引用
另外,如果你想对已存在的数据库生效,你需要在对应的数据库下执行以下命令:SET sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'; 引用
举个例子,如果你想在mt_user表中根据mobile字段进行分组,并且只显示那些mobile字段的值重复超过一次的记录,你可以执行以下查询:select id,mobile from mt_user group by mobile having count(1)>1; 但是,由于sql_mode设置为only_full_group_by,这个查询会报错,因为SELECT列表中的id字段没有在GROUP BY子句中列出。引用
因此,为了解决这个问题,你可以按照上述方法修改sql_mode设置,将only_full_group_by从中移除。这样就可以执行这个查询并得到正确的结果了。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [MySQL 8.0 修改 sql_mode=only_full_group_by](https://blog.csdn.net/qq_35349114/article/details/108277591)[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_2"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]