linux下如何关闭sql mode=only_full_group_by
时间: 2023-11-18 07:57:19 浏览: 44
在Linux下关闭MySQL的sql_mode=only_full_group_by,可以通过以下步骤实现:
1. 打开MySQL配置文件my.cnf,一般位于/etc/mysql/my.cnf或/etc/my.cnf。
2. 在[mysqld]下添加以下代码:
```
[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的,如果你还需要其他的sql_mode值,可以根据需要添加。
3. 保存并关闭my.cnf文件。
4. 重启MySQL服务,使配置生效。
```
sudo service mysql restart
```
相关问题:
相关问题
怎样设置 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='';
```
关闭MySQL sql_mode=only_full_group_by
关闭MySQL的sql_mode=only_full_group_by可以通过以下方法实现:
1. 修改配置文件:
- 打开MySQL的配置文件my.cnf或my.ini(根据操作系统的不同,文件路径可能会有所不同)。
- 在[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"
```
- 保存并关闭配置文件。
- 重启MySQL服务。
2. 临时修改会话:
- 打开MySQL客户端或命令行工具。
- 执行以下命令:
```sql
SET GLOBAL sql_mode = "STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION";
```
- 重新连接到MySQL服务器。
请注意,以上方法中的sql_mode值是一个示例,你可以根据自己的需求进行修改。另外,修改配置文件需要重启MySQL服务,而临时修改会话只对当前会话有效。