ENUM 类型

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

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

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

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

语法结构

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

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

  1. CREATE TABLE table_name (
  2. ...
  3. col ENUM ('value1','value2','value3'),
  4. ...
  5. );

语法解释

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

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

示例解释

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

  1. CREATE TABLE enumtable (
  2. id INT NOT NULL AUTO_INCREMENT,
  3. color ENUM('red', 'green', 'blue'),
  4. PRIMARY KEY (id)
  5. );

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

插入 ENUM 值

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

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

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

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

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

  1. CREATE TABLE enumtable (
  2. id INT NOT NULL AUTO_INCREMENT,
  3. color ENUM('red', 'green', 'blue') NOT NULL,
  4. PRIMARY KEY (id)
  5. );

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

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

与 MySQL 的差异

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

可以看这个例子:

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

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

限制

  1. 当前修改 ENUM 枚举成员需要使用 ALTER TABLE 语句重建表。