我们为什么不应该将数字存储到 MySQL ENUM 列?


MySQL 内部将 ENUM 值存储为整数键(索引号)以引用 ENUM 成员。不将整数值存储在 ENUM 列中的主要原因是,很明显的是,MySQL 最终引用索引而不是值,反之亦然。

示例

以下示例可以阐明这一问题 −

mysql> Create table enmtest(Val ENUM('0','1','2'));
Query OK, 0 rows affected (0.18 sec)

mysql> Insert into enmtest values('1'),(1);
Query OK, 2 rows affected (0.19 sec)
Records: 2 Duplicates: 0 Warnings: 0

mysql> Select * from enmtest;
+-----+
| Val |
+-----+
| 1   |
| 0   |
+-----+
2 rows in set (0.00 sec)

此处,我们插入 '1' 作为字符串,并意外地插入 1 作为数字(不带引号)。MySQL 令人困惑地将我们的数字输入用作索引值,即成员列表中第一项的内部引用(即 0)。

更新于: 20-Jun-2020

1K+ 查看次数

开始您的 事业

通过完成课程获得认证

开始
广告
© . All rights reserved.