sql_modesql_mode 是 MySQL 的 SQL 语法和行为控制开关,可以用来限制 SQL 的写法、控制数据校验严格度、以及兼容不同的 SQL 标准。
它主要影响:
sql_mode-- 会话级(当前连接有效)SELECT @@SESSION.sql_mode;-- 全局级(影响新连接)SELECT @@GLOBAL.sql_mode;php82 Bytes© 菜鸟-创作你的创作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 个字符 |
sql_modeSET SESSION sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_DATE,ONLY_FULL_GROUP_BY';php77 Bytes© 菜鸟-创作你的创作SET GLOBAL sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_DATE,ONLY_FULL_GROUP_BY';php76 Bytes© 菜鸟-创作你的创作注意:现有连接不会受影响,需要重新连接。
编辑配置文件:
/etc/my.cnf 或 /etc/mysql/my.cnfmy.ini添加:
[mysqld]sql_mode=STRICT_TRANS_TABLES,NO_ZERO_DATE,ONLY_FULL_GROUP_BYphp69 Bytes© 菜鸟-创作你的创作然后重启 MySQL:
systemctl restart mysqldphp24 Bytes© 菜鸟-创作你的创作sql_modeSHOW VARIABLES LIKE 'sql_mode';php31 Bytes© 菜鸟-创作你的创作不同版本默认值不同:
STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,ONLY_FULL_GROUP_BYNO_ZERO_IN_DATE, NO_ZERO_DATEsql_mode=NO_ENGINE_SUBSTITUTIONphp31 Bytes© 菜鸟-创作你的创作sql_mode=STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION,ONLY_FULL_GROUP_BYphp97 Bytes© 菜鸟-创作你的创作https://www.52runoob.com/archives/5522
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。