MySQL枚举类型enum字段在插入不在指定范围的值时, 是否是”插入了enum的第一个值”?…「建议收藏」

MySQL枚举类型enum字段在插入不在指定范围的值时, 是否是”插入了enum的第一个值”?…

大家好,又见面了,我是全栈君。

刚刚在看<<深入浅出MySQL>>一书的”ENUM类型”一节, 以下面的代码举例,

得出结论: “还可以看出对于不在ENUM指定范围内的值时, 并没有返回警告, 而是插入了enum(‘M’, ‘F’)的第一个值’M’

但是当我插入另外一种值’S’时, 却提示我”Data truncated for enumColumn at row 1″

我想问这个结论是否正确?

还是因为MySQL的版本问题呢

mysql> create table test(gender enum('M', 'F'));
Query OK, 0 rows affected (0.12 sec)

mysql> desc test;
+--------+---------------+------+-----+---------+-------+
| Field  | Type          | Null | Key | Default | Extra |
+--------+---------------+------+-----+---------+-------+
| gender | enum('M','F') | YES  |     | NULL    |       |
+--------+---------------+------+-----+---------+-------+
1 row in set (0.03 sec)

mysql> insert into test values('M'),('1'),('f'),(null);
Query OK, 4 rows affected (0.07 sec)
Records: 4  Duplicates: 0  Warnings: 0

mysql> select * from test;
+--------+
| gender |
+--------+
| M      |
| M      |
| F      |
| NULL   |
+--------+
4 rows in set (0.00 sec)

mysql>

  

不同 MySQL 版本处理方式不一样,像 5.5 这些默认不严格的会自动处理,5.7 及以上的默认是严格处理,所以会出错。

这个相当于是一个警告信息,在我本地测试的 5.7 中,直接插入会报错,但是使用 ignore 后,数据能被强制插入,但是是空值。

INSERT ignore INTO user (sex) VALUES (5);

在服务器使用 MySQL 5.5 测试 无论是否添加 ignore 数据都能被插入,但是是空值。

MySQL枚举类型enum字段在插入不在指定范围的值时, 是否是"插入了enum的第一个值"?...「建议收藏」

 

在 MySQL 枚举类型的“八宗罪” 这篇文章的第七条,文中提到了,如果不合法会被处理成空字符串,在后一段中又提到了因为类型的缘故,会根据枚举索引去取值。

在业务实践中,我们通常都是拒绝使用枚举进行数据控制。

MySQL枚举类型enum字段在插入不在指定范围的值时, 是否是"插入了enum的第一个值"?...「建议收藏」

 

总结:报错跟版本有关,5.5版无论是否添加igonre都可以插入,但是空值;

5.7版本添加ignore可以插入,但是空值;

不添加直接报错”ERROR 1265 (01000): Data truncated for column ‘genter’ at row 1“;

所以,建议开发中尽量不用枚举类型,免得报无谓的错误;

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/112173.html原文链接:https://javaforall.net

(0)
上一篇 2022年2月9日 下午3:00
下一篇 2022年2月9日 下午3:00


相关推荐

  • 构建风控评分卡模型介绍(WOE/KS/ROC)

    构建风控评分卡模型介绍(WOE/KS/ROC)什么是评分卡 信贷场景中 以分数的形式来衡量风险几率的一种手段 对未来一段时间内违约 逾期 失联概率的预测 通常评分越高越安全 根据使用场景分为反欺诈评分卡 申请评分卡 行为评分卡 催收评分卡为什么要开发评分卡风险控制的一个环节 根据已有数据提供逾期概率指标参考评分卡的特性稳定性 预测能力 等价于逾期概率评分卡开发的常用模型逻辑回归 决策树基于逻辑回归的评分卡理

    2026年3月19日
    2
  • idea2019.3激活码(注册激活)

    (idea2019.3激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/ide…

    2022年3月29日
    2.1K
  • js正则使用变量_JavaScript正则

    js正则使用变量_JavaScript正则varcookieName=”admin”; varcookie=document.cookie; varpat=newRegExp(“^”+cookieName+”=\\w*”,”g”);//输出的正则表达式/^admin=\w*/g

    2025年11月22日
    8
  • 计算机考研复试C语言常见面试题「建议收藏」

    计算机考研复试C语言常见面试题「建议收藏」本文是我2021年考研时准备的复试面试题,现在拿出来给大家分享一下觉得好的点个赞哦,毕竟当初我也是整理了好久,改了好几次版本呢祝大家都上岸!!!!P.S.我当初整理的时候是word,直接复制过来的话代码不会自动变成CSDN的代码块,所以代码我是一段一段重新标记为CSDN代码段的,这样大家看起来舒服点C语言基础目录1、static关键字的作用22、C++和C的区别23、Java的方法重载24、重写和重载25、面向对象编程36、c++可以有多个父类37

    2022年8月29日
    5
  • 通俗易懂的Mybatis工作原理[通俗易懂]

    作为半自动的ORM框架,Mybatis被越来越多的企业接受。搞清楚它的工作原理以及底层实现,对于开发者可事半功倍。很多文章都是使用大批量的源码流程去分析原理。对于有源码阅读功底的开发者,也许还能招架住,但还是不直观。我以前的很多文章都是这么做的,后来有朋友私信建议说,这些文章类似于个人笔记,只能自己阅读,不利于分享,所以,本文将尝试采用通俗易懂的白话文带领大家认识一下Mybatis的工作原理。(PS:大家可以设想,如果自己在开发Mybatis,该如何设计好Mybatis的功能呢?)一...

    2022年4月17日
    45
  • uniqid php 重复_如何使用php中uniqid函数生成唯一的id

    uniqid php 重复_如何使用php中uniqid函数生成唯一的idphp 中的 uniqid 是一个根据当前时间生成唯一值 ID 的函数 接下来的这篇文章我们就来详细介绍 php 中 uniqid 函数生成唯一的 id 的方法 php 中的 uniqid 虽然是生成唯一的值 但是因为是基于当前时间以微秒同时在多个服务器 所以当运行 uniqid 时可能会产生相同的值 此问题可以通过应用前缀 prefix 指定一个参数从而避免 它是使用 rand 函数为前缀指定一个随机值 此外 它可用于上传图像

    2026年3月17日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号