📣

TiDB Cloud Serverless 现已更名为
Starter
!此页面由 AI 自动翻译,英文原文请见
此处。

默认值

数据类型规范中的 DEFAULT 值子句表示列的默认值。

你可以为所有数据类型设置默认值。通常,默认值必须是常量,不能是函数或表达式,但也有一些例外:

  • 对于时间类型,可以使用 NOWCURRENT_TIMESTAMPLOCALTIMELOCALTIMESTAMP 函数作为 TIMESTAMPDATETIME 列的默认值。
  • 对于整数类型,可以使用 NEXT VALUE FOR 函数将序列的下一个值设置为列的默认值,并使用 RAND() 函数生成一个随机浮点值作为列的默认值。
  • 对于字符串类型,可以使用 UUID() 函数生成一个 通用唯一标识符 (UUID) 作为列的默认值。
  • 对于二进制类型,可以使用 UUID_TO_BIN() 函数将 UUID 转换为二进制格式,并将转换后的值设置为列的默认值。
  • 从 v8.0.0 版本开始,TiDB 还支持为 BLOBTEXTJSON 数据类型指定默认值,但只能使用表达式为它们设置 默认值

如果列定义中没有明确的 DEFAULT 值,TiDB 将按如下方式确定默认值:

  • 如果该列可以取 NULL,则定义时显式包含 DEFAULT NULL 子句。
  • 如果该列不能取 NULL,则定义时不包含显式的 DEFAULT 子句。

对于没有显式 DEFAULT 子句的 NOT NULL 列在插入或替换(INSERTREPLACE)语句中未提供该列的值时,TiDB 会根据当时生效的 SQL 模式处理该列:

  • 如果启用了严格 SQL 模式,对于事务性表会报错并回滚该语句;对于非事务性表,也会报错。
  • 如果未启用严格模式,TiDB 会将该列设置为该列数据类型的隐式默认值。

隐式默认值定义如下:

  • 对于数值类型,默认值为 0。如果声明了 AUTO_INCREMENT 属性,则默认值为序列的下一个值。
  • 对于除 TIMESTAMP 以外的日期和时间类型,默认值为该类型的“零”值。对于 TIMESTAMP,默认值为当前日期和时间。
  • 对于除 ENUM 以外的字符串类型,默认值为空字符串。对于 ENUM,默认值为第一个枚举值。

指定表达式为默认值

从 8.0.13 版本开始,MySQL 支持在 DEFAULT 子句中指定表达式作为默认值。更多信息请参见 MySQL 8.0.13 版本起显式默认值处理

TiDB 支持在 DEFAULT 子句中指定以下表达式作为默认值。

TiDB 支持为 BLOBTEXTJSON 数据类型赋予默认值,但只能使用表达式,不能使用字面量定义这些数据类型的默认值。以下是 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}') );

最后两个示例显示了类似的默认值,但只有第一个示例有效,因为它使用了表达式而非字面量。

文档内容是否有帮助?