为什么我们不应该将数字存储到 MySQL ENUM 列中?
mysqlmysqli database
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)。