关闭mysql的sql_mode=only_full_group_by
时间: 2023-09-20 14:13:42 浏览: 130
要关闭 MySQL 的 `sql_mode=only_full_group_by`,可以按照以下步骤进行:
1. 打开 MySQL 配置文件,找到 `sql_mode` 这一行,将其中的 `ONLY_FULL_GROUP_BY` 前面的注释符号 `#` 去掉,或者将整个 `sql_mode` 行注释掉。
2. 保存并关闭 MySQL 配置文件。
3. 重启 MySQL 服务,使更改生效。
如果您不知道 MySQL 配置文件的位置,可以使用以下命令进行查找:
```
sudo find / -name "my.cnf"
```
这个命令会在整个文件系统中查找名为 `my.cnf` 的文件,并输出文件路径。如果您使用的是 macOS 或者类 Unix 系统,也可以在终端输入以下命令来查找 MySQL 配置文件:
```
sudo vi /etc/mysql/mysql.conf.d/mysqld.cnf
```
如果您使用的是 Windows 系统,MySQL 配置文件通常位于 `C:\Program Files\MySQL\MySQL Server X.X\my.ini` 或者 `C:\ProgramData\MySQL\MySQL Server X.X\my.ini`,其中 `X.X` 是 MySQL 版本号。
相关问题
mysql 分组报错sql_mode=only_full_group_by
这是因为在 MySQL 5.7 版本以后默认启用了 ONLY_FULL_GROUP_BY 模式,该模式下分组查询的字段必须要么是分组字段本身,要么是使用聚合函数的字段。如果分组查询的字段既不是分组字段本身,也没有使用聚合函数,那么就会报错。
如果你想要取消 ONLY_FULL_GROUP_BY 模式,可以在 MySQL 配置文件中修改 sql_mode 的值,去掉其中的 ONLY_FULL_GROUP_BY。如果你不想修改全局配置,也可以在查询中使用如下语句来临时关闭该模式:
```
SET sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));
```
需要注意的是,关闭 ONLY_FULL_GROUP_BY 模式可能会导致一些不符合预期的查询结果,因此需要谨慎使用。
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 ]
阅读全文