为什么我们不应该将数字存储到 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)。
Advertisement 广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP