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

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

数据库 2024-02-04 23:41:04 1年以前

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)。

文章版权声明:除非注明,否则均为网络转载文章,转载或复制请以超链接形式并注明出处。