MySQL的sql_mode模式说明及设置

1. 什么是 sql_mode

sql_mode 是 MySQL 的 SQL 语法和行为控制开关,可以用来限制 SQL 的写法、控制数据校验严格度、以及兼容不同的 SQL 标准。

它主要影响:

  • 语法规则(是否允许非标准 SQL)
  • 数据校验(插入无效值时是报错还是自动转换)
  • 日期和时间格式
  • GROUP BY 行为
  • 兼容性(MySQL vs SQL Server / PostgreSQL 等)

2. 查看当前 sql_mode

sql 复制代码
-- 会话级(当前连接有效)
SELECT @@SESSION.sql_mode;
-- 全局级(影响新连接)
SELECT @@GLOBAL.sql_mode;
php
82 Bytes
© 菜鸟-创作你的创作

3. 常见 sql_mode 选项说明

模式 作用 例子
STRICT_TRANS_TABLES 严格模式:插入无效值时报错 插入超长字符串时直接报错
NO_ZERO_IN_DATE 禁止日期中出现零的月/日 '2023-00-05' 报错
NO_ZERO_DATE 禁止 '0000-00-00' 作为日期 插入该日期时报错
ERROR_FOR_DIVISION_BY_ZERO 除零时报错而不是返回 NULL SELECT 1/0 报错
ONLY_FULL_GROUP_BY GROUP BY 必须包含非聚合列 不能 SELECT col1, MAX(col2) GROUP BY col1 之外的列
ANSI_QUOTES " 变为标识符引用符 SELECT "col" 表示列而不是字符串
TRADITIONAL 启用严格的 SQL 行为,组合多种严格模式 类似 Oracle/PostgreSQL 严格模式
PAD_CHAR_TO_FULL_LENGTH CHAR 类型字段返回补足空格 CHAR(10) 总是返回 10 个字符

4. 设置 sql_mode

(1)会话级设置(仅当前连接有效)

ini 复制代码
SET SESSION sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_DATE,ONLY_FULL_GROUP_BY';
php
77 Bytes
© 菜鸟-创作你的创作

(2)全局级设置(影响新连接)

ini 复制代码
SET GLOBAL sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_DATE,ONLY_FULL_GROUP_BY';
php
76 Bytes
© 菜鸟-创作你的创作

注意:现有连接不会受影响,需要重新连接。


5. 持久化设置(重启后生效)

MySQL 8.0+(推荐)

编辑配置文件:

  • Linux/etc/my.cnf/etc/mysql/my.cnf
  • Windowsmy.ini

添加:

ini 复制代码
[mysqld]
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_DATE,ONLY_FULL_GROUP_BY
php
69 Bytes
© 菜鸟-创作你的创作

然后重启 MySQL:

复制代码
systemctl restart mysqld
php
24 Bytes
© 菜鸟-创作你的创作

6. 查看 MySQL 默认 sql_mode

sql 复制代码
SHOW VARIABLES LIKE 'sql_mode';
php
31 Bytes
© 菜鸟-创作你的创作

不同版本默认值不同:

  • MySQL 5.7 默认开启 STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,ONLY_FULL_GROUP_BY
  • MySQL 8.0 默认去掉 NO_ZERO_IN_DATE, NO_ZERO_DATE

7. 推荐设置方案

  • 开发环境(宽松,方便调试):
ini 复制代码
sql_mode=NO_ENGINE_SUBSTITUTION
php
31 Bytes
© 菜鸟-创作你的创作
  • 生产环境(严格,避免脏数据):
ini 复制代码
sql_mode=STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION,ONLY_FULL_GROUP_BY
php
97 Bytes
© 菜鸟-创作你的创作

www.52runoob.com/archives/55...

相关推荐
行百里er3 小时前
WebSocket 在 Spring Boot 中的实战解析:实时通信的技术利器
spring boot·后端·websocket
再学一点就睡3 小时前
前端网络实战手册:15个高频工作场景全解析
前端·网络协议
C_心欲无痕4 小时前
有限状态机在前端中的应用
前端·状态模式
C_心欲无痕4 小时前
前端基于 IntersectionObserver 更流畅的懒加载实现
前端
candyTong4 小时前
深入解析:AI 智能体(Agent)是如何解决问题的?
前端·agent·ai编程
柳杉4 小时前
建议收藏 | 2026年AI工具封神榜:从Sora到混元3D,生产力彻底爆发
前端·人工智能·后端
weixin_462446234 小时前
使用 Puppeteer 设置 Cookies 并实现自动化分页操作:前端实战教程
运维·前端·自动化
仙俊红4 小时前
spring的IoC(控制反转)面试题
java·后端·spring
CheungChunChiu4 小时前
Linux 内核动态打印机制详解
android·linux·服务器·前端·ubuntu
小楼v4 小时前
说说常见的限流算法及如何使用Redisson实现多机限流
java·后端·redisson·限流算法