zoukankan      html  css  js  c++  java
  • 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 枚举类型的“八宗罪” 这篇文章的第七条,文中提到了,如果不合法会被处理成空字符串,在后一段中又提到了因为类型的缘故,会根据枚举索引去取值。

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

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

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

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

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

  • 相关阅读:
    UVA11367 Full Tank?
    不均衡样本集问题
    NLP interview
    Linux 指令
    Python 趣题
    Grid Illumination
    动态规划-Minimum Cost to Merge Stones
    Contest 141
    Python join()方法
    Single Number
  • 原文地址:https://www.cnblogs.com/lxwphp/p/15453215.html
Copyright © 2011-2022 走看看