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


相关推荐

  • Python爬虫框架Scrapy获得定向打击批量招聘信息

    Python爬虫框架Scrapy获得定向打击批量招聘信息

    2022年1月13日
    57
  • HTML 文本两端对齐

    HTML 文本两端对齐pstyle text align justify text justify inter ideograph 日本驻华大使丹羽宇一郎 日中关系比夫妻还紧密日本驻华大使丹羽宇一郎 日中关系比夫妻还紧密日本驻华大使丹羽宇一郎 日中关系比夫妻还紧密日本驻华大使丹羽宇一郎 日中关系比夫妻还紧密 text align justify 是文本对齐标签只是英文字体有效 pstyle text align justify text justify inter ideograph

    2026年3月16日
    3
  • Python locals() 的陷阱

    Python locals() 的陷阱在工作中 有时候会遇到一种情况 动态地进行变量赋值 不管是局部变量还是全局变量 在我们绞尽脑汁的时候 Python 已经为我们解决了这个问题 Python 的命名空间通过一种字典的形式来体现 而具体到函数也就是 locals 和 globals 分别对应着局部命名空间和全局命名空间 于是 我们也就能通过这些方法去实现我们 动态赋值 的需求 例如 deftest

    2026年3月17日
    2
  • FFmpeg 硬编码

    FFmpeg 硬编码h264 硬编解码 ffmpegFFmpeg 调用 AndroidMedia 进行硬解码 FFmpeg 要确保打开了 mediacodec 相关的选项 具体如下 enable mediacodecen decoder h264 mediacodecen decoder hevc mediacodecen decoder mpeg4 mediacodecen hwaccel h264 mediacodec

    2026年3月26日
    3
  • jave中的Random中rand.nextInt(int n )的取值范围

    jave中的Random中rand.nextInt(int n )的取值范围1.要求在10到300中产生随机数[10,300]包含10和300.intrandNum=rand.nextInt(300-10+1)+10;rand.nextInt(300-10+1)=rand.nextInt(291)意思是产生[0,291)不包括291再加10就是[10,301)不包括301,如果要包括300所以要rand.nextInt(300-10+1)里面要加1.

    2022年7月22日
    72
  • goland远程调试k8s上容器

    goland远程调试k8s上容器goland 远程调试 k8s 上容器上次也遇到过一次需要在 k8s 的容器里 debug 程序的情况 当时找了个偷懒的办法绕过去了 这回绕不过去了 老老实实整一把 主要还是用 dlv 配合 goland 的远程调试功能

    2026年3月18日
    2

发表回复

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

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