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

刚刚在看<>一书的"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 数据都能被插入,但是是空值。

41740f152f0250398c12abef98a2cac2.png

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

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

2e080c9746a0a0a53fc209d6919d96ef.png

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

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

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值