默认值
数据类型规范中的 DEFAULT 值子句表示列的默认值。
你可以为所有数据类型设置默认值。通常,默认值必须是常量,不能是函数或表达式,但也有一些例外:
- 对于时间类型,可以使用
NOW、CURRENT_TIMESTAMP、LOCALTIME和LOCALTIMESTAMP函数作为TIMESTAMP和DATETIME列的默认值。 - 对于整数类型,可以使用
NEXT VALUE FOR函数将序列的下一个值设置为列的默认值,并使用RAND()函数生成一个随机浮点值作为列的默认值。 - 对于字符串类型,可以使用
UUID()函数生成一个 通用唯一标识符 (UUID) 作为列的默认值。 - 对于二进制类型,可以使用
UUID_TO_BIN()函数将 UUID 转换为二进制格式,并将转换后的值设置为列的默认值。 - 从 v8.0.0 版本开始,TiDB 还支持为
BLOB、TEXT和JSON数据类型指定默认值,但只能使用表达式为它们设置 默认值。
如果列定义中没有明确的 DEFAULT 值,TiDB 将按如下方式确定默认值:
- 如果该列可以取
NULL,则定义时显式包含DEFAULT NULL子句。 - 如果该列不能取
NULL,则定义时不包含显式的DEFAULT子句。
对于没有显式 DEFAULT 子句的 NOT NULL 列在插入或替换(INSERT 或 REPLACE)语句中未提供该列的值时,TiDB 会根据当时生效的 SQL 模式处理该列:
- 如果启用了严格 SQL 模式,对于事务性表会报错并回滚该语句;对于非事务性表,也会报错。
- 如果未启用严格模式,TiDB 会将该列设置为该列数据类型的隐式默认值。
隐式默认值定义如下:
- 对于数值类型,默认值为 0。如果声明了
AUTO_INCREMENT属性,则默认值为序列的下一个值。 - 对于除
TIMESTAMP以外的日期和时间类型,默认值为该类型的“零”值。对于TIMESTAMP,默认值为当前日期和时间。 - 对于除
ENUM以外的字符串类型,默认值为空字符串。对于ENUM,默认值为第一个枚举值。
指定表达式为默认值
从 8.0.13 版本开始,MySQL 支持在 DEFAULT 子句中指定表达式作为默认值。更多信息请参见 MySQL 8.0.13 版本起显式默认值处理。
TiDB 支持在 DEFAULT 子句中指定以下表达式作为默认值。
UPPER(SUBSTRING_INDEX(USER(), '@', 1))REPLACE(UPPER(UUID()), '-', '')- 以下格式的
DATE_FORMAT表达式:DATE_FORMAT(NOW(), '%Y-%m')DATE_FORMAT(NOW(), '%Y-%m-%d')DATE_FORMAT(NOW(), '%Y-%m-%d %H.%i.%s')DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%s')
STR_TO_DATE('1980-01-01', '%Y-%m-%d')CURRENT_TIMESTAMP()、CURRENT_DATE():都使用默认的小数秒精度(fsp)JSON_OBJECT()、JSON_ARRAY()、JSON_QUOTE()NEXTVAL()RAND()UUID()、UUID_TO_BIN()VEC_FROM_TEXT()
TiDB 支持为 BLOB、TEXT 和 JSON 数据类型赋予默认值,但只能使用表达式,不能使用字面量定义这些数据类型的默认值。以下是 BLOB 的示例:
CREATE TABLE t2 (
b BLOB DEFAULT (RAND())
);
使用 UUID 的示例:
CREATE TABLE t3 (
uuid BINARY(16) DEFAULT (UUID_TO_BIN(UUID())),
name VARCHAR(255)
);
关于如何使用 UUID 的更多信息,请参见 使用 UUID 作为主键的最佳实践。
使用 JSON 的示例:
CREATE TABLE t4 (
id bigint AUTO_RANDOM PRIMARY KEY,
j json DEFAULT (JSON_OBJECT("a", 1, "b", 2))
);
不允许的 JSON 示例:
CREATE TABLE t5 (
id bigint AUTO_RANDOM PRIMARY KEY,
j json DEFAULT ('{"a": 1, "b": 2}')
);
最后两个示例显示了类似的默认值,但只有第一个示例有效,因为它使用了表达式而非字面量。