sql-mode="ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"
时间: 2023-10-13 21:08:03 浏览: 36
sql-mode是MySQL中的一个系统变量,用于设置SQL执行的模式。在这个设置中,包括了以下几个模式:
- ONLY_FULL_GROUP_BY:当使用GROUP BY语句时,要求SELECT查询的列必须是GROUP BY子句中的列或者是聚合函数。
- STRICT_TRANS_TABLES:启用严格的事务表模式,在插入或更新数据时,如果数据类型不匹配或者值不符合约束条件,将会报错。
- NO_ZERO_IN_DATE:禁止在日期和时间中使用'0000-00-00'或者'0000-00-00 00:00:00',这样的值将会被视为无效。
- NO_ZERO_DATE:禁止在日期和时间中使用'0000-00-00',这样的值将会被视为无效。
- ERROR_FOR_DIVISION_BY_ZERO:当除数为零时,执行除法运算将会报错。
- NO_ENGINE_SUBSTITUTION:如果存储引擎不可用,将不会替代使用其他存储引擎。
相关问题
数据库如何修改sql_mode=only_full_group_by
可以通过以下三种方式修改MySQL数据库的sql_mode=only_full_group_by:
1. 临时修改:可以在MySQL客户端中执行以下命令来临时修改sql_mode:
```
SET @@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只在当前会话中有效,MySQL重启后会失效。
2. 永久修改:可以修改MySQL配置文件my.cnf或my.ini,在[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
```
修改完毕后需要重启MySQL服务才能生效。
3. 在MySQL命令行中修改:可以在MySQL命令行中执行以下命令来修改sql_mode:
```
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';
```
这种方式修改的sql_mode会立即生效,但MySQL重启后会失效。
关闭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服务,而临时修改会话只对当前会话有效。