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

举报
lxw1844912514 发表于 2022/03/27 03:01:06 2022/03/27
【摘要】 刚刚在看<<深入浅出MySQL>>一书的"ENUM类型"一节, 以下面的代码举例, 得出结论: "还可以看出对于不在ENUM指定范围内的值时, 并没有返回警告, 而是插入了enum('M', 'F')的第一个值'M'" 但是当我插入另外一种值'S'时, 却提示我"Data truncated for...

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

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

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

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

还是因为MySQL的版本问题呢


    
  1. mysql> create table test(gender enum('M', 'F'));
  2. Query OK, 0 rows affected (0.12 sec)
  3. mysql> desc test;
  4. +--------+---------------+------+-----+---------+-------+
  5. | Field | Type | Null | Key | Default | Extra |
  6. +--------+---------------+------+-----+---------+-------+
  7. | gender | enum('M','F') | YES | | NULL | |
  8. +--------+---------------+------+-----+---------+-------+
  9. 1 row in set (0.03 sec)
  10. mysql> insert into test values('M'),('1'),('f'),(null);
  11. Query OK, 4 rows affected (0.07 sec)
  12. Records: 4 Duplicates: 0 Warnings: 0
  13. mysql> select * from test;
  14. +--------+
  15. | gender |
  16. +--------+
  17. | M |
  18. | M |
  19. | F |
  20. | NULL |
  21. +--------+
  22. 4 rows in set (0.00 sec)
  23. mysql>

  

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

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

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

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

 

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

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

 

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

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

不添加直接报错"ERROR 1265 (01000): Data truncated for column 'genter' at row 1";

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

 

文章来源: blog.csdn.net,作者:lxw1844912514,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/lxw1844912514/article/details/100028339

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。