首页 > 数据库 > mysql教程 > 为什么我们不应该将数字存储到 MySQL ENUM 列中?

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

WBOY
发布: 2023-09-04 12:29:09
转载
1274 人浏览过

为什么我们不应该将数字存储到 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)。

以上是为什么我们不应该将数字存储到 MySQL ENUM 列中?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:tutorialspoint.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板