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: 0mysql> select * from enmtest;+-----+| val |+-----+| 1 || 0 |+-----+2 rows in set (0.00 sec)
在这里,我们将‘1’作为字符串插入,不小心还插入了一个没有引号的数字1。mysql混淆地使用我们的数字输入作为索引值,即对成员列表中的第一项的内部引用(即0)。
以上就是为什么我们不应该将数字存储到 mysql enum 列中?的详细内容。
