登录
首页 >  数据库 >  MySQL

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

来源:tutorialspoint

时间:2023-08-26 07:59:46 200浏览 收藏

亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《为什么我们不应该将数字存储到 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 列中?》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于数据库的相关知识,请关注golang学习网公众号!

声明:本文转载于:tutorialspoint 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>