默认值用于插入记录时自动填充未指定字段,确保数据完整性。通过DEFAULT关键字可设置常量、CURRENT_TIMESTAMP等动态值,支持减少SQL书写、保证字段合理取值,但TEXT/BLOB类型受限,且NOT NULL字段必须设默认值以防报错。

在MySQL中,默认值(DEFAULT) 是指当插入新记录时,若未显式为某列提供值,系统自动填充的预设值。理解并合理设置默认值,有助于保证数据完整性、减少应用层处理逻辑,并提升数据库操作效率。
默认值的作用与意义
默认值主要用于处理“空缺字段”的场景。例如用户注册时未填写年龄,系统可自动设为0或NULL;创建时间字段通常设为当前时间。这样避免了因字段缺失导致的插入失败或数据不一致问题。
使用默认值的好处包括:
- 减少INSERT语句的字段书写量
- 确保关键字段始终有合理取值
- 支持动态值(如CURRENT_TIMESTAMP)自动生效
如何设置默认值
在建表或修改表结构时,可通过 DEFAULT 关键字指定默认值。
CREATE TABLE users ( id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(50) NOT NULL, age INT DEFAULT 0, status TINYINT DEFAULT 1, created_at DATETIME DEFAULT CURRENT_TIMESTAMP );上述语句中:
- age 默认为 0,表示未提供时视为0岁
- status 默认为1(可用状态)
- created_at 自动记录当前时间
也可通过ALTER TABLE添加或修改默认值:
默认值的常见类型与限制
MySQL支持多种类型的默认值设置,但也存在一些限制:
- 常量值:如 DEFAULT 0、DEFAULT 'unknown'
- 表达式:仅部分函数允许,如 CURRENT_TIMESTAMP、NOW()、CURDATE() 等
- 不能使用普通函数或子查询作为默认值(如 DEFAULT UUID() 在旧版本中不支持)
- TEXT 和 BLOB 类型字段不能设置默认值(除非是TEXT的变体如TINYTEXT且在特定模式下)
- NULL 可作为默认值,前提是字段允许为NULL
INSERT行为与默认值的关系
以下几种写法会触发默认值生效:
- INSERT INTO users (name) VALUES ('Alice'); —— 其他字段用默认值填充
- INSERT INTO users VALUES (); —— 所有字段使用默认值(需支持)
- INSERT INTO users SET name='Bob'; —— 显式省略的字段走默认逻辑
而以下情况不会使用默认值:
- INSERT 中显式传入 NULL(除非列允许且无特殊约束)
- 字段定义为 NOT NULL 且无 DEFAULT,插入时又未提供值,则报错
基本上就这些。掌握默认值机制,能让你的表设计更健壮,减少不必要的错误和代码冗余。关键是根据业务需求合理设定,同时注意MySQL版本对功能的支持差异。










