当前位置: 首页 > 编程笔记 >

为什么不将数字存储到MySQL ENUM列中?

顾乐池
2023-03-14
本文向大家介绍为什么不将数字存储到MySQL ENUM列中?,包括了为什么不将数字存储到MySQL ENUM列中?的使用技巧和注意事项,需要的朋友参考一下

MySQL内部将ENUM值存储为整数键(索引号),以引用ENUM成员。不将整数值存储在ENUM列中的主要原因是,很明显,MySQL最终引用了索引而不是值,反之亦然。

示例

以下示例可以澄清它-

mysql> Create table enmtest(Val ENUM('0','1','2'));

mysql> Insert into enmtest values('1'),(1);
Records: 2 Duplicates: 0 Warnings: 0

mysql> Select * from enmtest;
+-----+
| Val |
+-----+
| 1   |
| 0   |
+-----+
2 rows in set (0.00 sec)

在这里,我们将'1'作为字符串插入,并且偶然也将1作为数字插入(不带引号)。MySQL混淆地使用我们的数字输入作为索引值,即对成员列表中第一项(即0)的内部引用。

 类似资料:
  • 我试图理解将jwt存储在本地存储(倾向于xss)与cookie(倾向于csrf)的安全含义。我想了解如果我将jwt令牌存储在前端的应用状态中的安全性影响,就像在redux商店中一样。 编辑: 我试图了解有关存储代币的更多信息。似乎所有的文章和答案实际上都是在确定有两种方法可以做到这一点后开始讨论的,即cookie或浏览器存储。像这样一个相关的问题:在浏览器中的何处存储JWT?如何防范CSRF?像这

  • 在我的springbootapp中,我有以下存储库:- 当我运行这个应用程序时。我收到了这个错误:- 启动ApplicationContext时出错。要显示条件报告,请在启用“调试”的情况下重新运行应用程序。2020-12-24 21:09:15 - 应用程序启动失败 说明: com中构造函数的参数0。如何使用Java。演示。存储库。RevisionRepository需要“org”类型的bean

  • 错误: 代码: 自<代码>列表

  • 这个问题涵盖了一个软件算法 我正在解决亚马逊软件问题中的一个面试问题,特别是< br >“给定一组点(x,y)和一个整数“n”,返回n个接近原点的点” 下面是这个问题的高级伪代码示例答案,来自示例答案 步骤1:设计一个名为point的类,它有三个字段-int x,int y,int distance 第2步:对于所有给定的点,找到它们与原点之间的距离 第一步:将值存储在二叉树中 我同意步骤1和2,

  • 问题内容: 有人可以告诉我,在以下情况下如何进行? 接收文件(MS文件,ODS,PDF) 通过Apache Tika提取公元核心元数据+通过jackrabbit-content-extractors提取内容 使用Jackrabbit将文档(内容)及其元数据存储到存储库中 ? 检索文档+元数据 我对第3点和第4点感兴趣… 详细信息:该应用程序正在以交互方式处理文档(一些分析-语言检测,单词计数等。+

  • 我有问题将列表字段存储为cassandra数据库中我的表的字段。 我使用的是spring-数据-卡桑德拉,版本1.4.1,发布版。 我的模型包含: 我想用SchemaAction自动创建我的db表。配置类中的recreate_drop_unused架构操作: 它尝试创建表,但发生以下异常: