Skip to content

ENUM 类型

ENUM 是一个字符串的列表,ENUM 用于存储一组预定义的离散值。它可以定义一个具有离散值的类型,每个枚举常量都代表了一个特定的值。

ENUM 数据类型列适合存储状态和标识等有限数量的固定值的数据。

ENUM 数据类型具有以下优点:

  • 列值的可读性更强。
  • 紧凑的数据存储。MatrixOne 存储 ENUM 时只存储枚举值对应的数字索引 (1, 2, 3, …)。

语法结构

ENUM ('value1', 'value2', ..., 'valuen')

例如,定义 ENUM 列,你可以使用以下语法:

CREATE TABLE table_name (
    ...
    col ENUM ('value1','value2','value3'),
    ...
);

语法解释

  • ENUM 是一个关键字,用来声明一个枚举类型。
  • value1 到 valuen 是此 ENUM 类型的可选项列表,使用 ENUM 类型的列的值只能是上面值中的其中一个。
  • 枚举值可以是 string、int 或 time 类型。

Note:ENUM 数据类型中,你可以拥有多个枚举值。但是,建议将枚举值的数量保持在 20 以下。

示例解释

ENUM 类型的值必须从一个预定义的值列表中选择,下面的例子将帮助你理解:

CREATE TABLE enumtable (
    id INT NOT NULL AUTO_INCREMENT,
    color ENUM('red', 'green', 'blue'),
    PRIMARY KEY (id)
);

上述语句将创建一个名为 enumtable 的表,其中包含一个名为 color 的枚举类型字段。color 字段的值必须为 redgreenblue 中的一个。同时,按照列定义时的顺序,redgreenblue 的索引分别为 1,2,3。

插入 ENUM 值

当向枚举类型的字段中插入数据时,只能插入预定义的枚举值或者 NULL。如果插入的值不在预定义的列表中,则产生报错。例如:

INSERT INTO enumtable (id, color) VALUES ('01', 'red');
-- 'red' 在预定义的列表中,插入成功
INSERT INTO enumtable (id, color) VALUES ('02', 'yellow');
-- 'yellow' 不在预定义的列表中,则会产生报错
INSERT INTO enumtable (id, color) VALUES ('03', NULL);
-- 枚举成员并没有定义 not null,插入成功

除了枚举值,还可以使用枚举成员的数字索引将数据插入到 ENUM 列中。例如:

INSERT INTO enumtable (id, color) VALUES ('04', 2);
-- 由于 `green` 的索引是 2,所以这条数据插入成功
  • 非空约束对于 ENUM 的限制

假如建表时,我们定义了 colorNOT NULL

CREATE TABLE enumtable (
    id INT NOT NULL AUTO_INCREMENT,
    color ENUM('red', 'green', 'blue') NOT NULL,
    PRIMARY KEY (id)
);

当插入一个新行而不指定 color 列的值时,MatrixOne 将使用第一个枚举成员作为默认值:

INSERT INTO enumtable (id) VALUES ('05');
-- 这里将给 id 为 05 的列指定第一个枚举成员 `red` 为默认值

与 MySQL 的差异

与 MySQL 不同的是,MatrixOne 的 ENUM 类型在 WHERE 条件里只能跟字符串类型进行比较。

可以看这个例子:

update orders set status= 2 where status='Processing';`

在这个示例中,你需要将 statusProcessing 的行的 status 更新为 2。由于 ENUM 类型的特性,在 WHERE 条件中,MatrixOne 将 2 隐式地转换为字符串 2,然后与 Processing 进行比较。

限制

  1. 当前修改 ENUM 枚举成员需要使用 ALTER TABLE 语句重建表。
  2. MatrixOne 暂不支持过滤 ENUM 值排序 ENUM 值