当前位置 博文首页 > 文章内容

    MySQL中关于null值的一个小问题

    作者:shunshunshun18 栏目:未分类 时间:2021-03-25 14:44:49

    本站于2023年9月4日。收到“大连君*****咨询有限公司”通知
    说我们IIS7站长博客,有一篇博文用了他们的图片。
    要求我们给他们一张图片6000元。要不然法院告我们

    为避免不必要的麻烦,IIS7站长博客,全站内容图片下架、并积极应诉
    博文内容全部不再显示,请需要相关资讯的站长朋友到必应搜索。谢谢!

    另祝:版权碰瓷诈骗团伙,早日弃暗投明。

    相关新闻:借版权之名、行诈骗之实,周某因犯诈骗罪被判处有期徒刑十一年六个月

    叹!百花齐放的时代,渐行渐远!



        今天在测试null值的时候,发现了一个小问题,记录在这里,不知道大家以前遇到过没。

        事情发展是这样的,在过滤一个表中的数值的时候,需要把age=2的列给剔除掉,然后查看剩余的列信息,这个操作看起来比较简单,我用一个表模拟一下过程:

    CREATE TABLE `test` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `age` int(11) DEFAULT NULL,
      `score` varchar(20) NOT NULL DEFAULT '',
      PRIMARY KEY (`id`),
      KEY `idx_score` (`score`)
    ) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8

      表结构如上,其中id和score都加了not null的限制,而age字段没有添加这个约束,然后我们先插入一部分数据,如下:

    mysql:yeyztest 23:32:57>>select * from test;
    +----+------+-------+
    | id | age  | score |
    +----+------+-------+
    |  1 |    1 | 5     |
    |  2 |    2 | 10    |
    |  5 |    5 | 25    |
    |  8 |    8 | 40    |
    |  9 |    2 | 45    |
    | 10 |    5 | 50    |
    | 11 |    8 | 55    |
    +----+------+-------+
    7 rows in set (0.00 sec)

       当前这组数据是全量的,每个字段都有值,然后我们使用下面的SQL语句来查询制定记录:

    select * from test where id != 2;

    我们查看结果:

    mysql:yeyztest 23:33:14>>select * from test where age!=2;
    +----+------+-------+
    | id | age  | score |
    +----+------+-------+
    |  1 |    1 | 5     |
    |  5 |    5 | 25    |
    |  8 |    8 | 40    |
    | 10 |    5 | 50    |
    | 11 |    8 | 55    |
    +----+------+-------+
    5 rows in set (0.00 sec)

    此时我们插入两条记录进去:

    mysql:yeyztest 23:33:17>>insert into test (id,score) values (12,60);
    Query OK, 1 row affected (0.00 sec)
    
    mysql:yeyztest 23:34:02>>insert into test (id,score) values (13,65);
    Query OK, 1 row affected (0.00 sec)
    
    mysql:yeyztest 23:34:10>>select * from test;
    +----+------+-------+
    | id | age  | score |
    +----+------+-------+
    |  1 |    1 | 5     |
    |  2 |    2 | 10    |
    |  5 |    5 | 25    |
    |  8 |    8 | 40    |
    |  9 |    2 | 45    |
    | 10 |    5 | 50    |
    | 11 |    8 | 55    |
    | 12 | NULL | 60    |
    | 13 | NULL | 65    |
    +----+------+-------+
    9 rows in set (0.00 sec)

    再次使用上面的语句进行查询,可以看到结果如下:

    mysql:yeyztest 23:34:15>>select * from test where age!=2;
    +----+------+-------+
    | id | age  | score |
    +----+------+-------+
    |  1 |    1 | 5     |
    |  5 |    5 | 25    |
    |  8 |    8 | 40    |
    | 10 |    5 | 50    |
    | 11 |    8 | 55    |
    +----+------+-------+
    5 rows in set (0.00 sec)

       也就是说,当记录中包含null值的时候,使用反向匹配age!=2是无法得到全量的查询结果的,这明显不符合我们的预期。

       其实这个问题,在之前的文章中有说到过,就是在一条数据记录里面,null值字段和一般的字段是不在一起存储的,null值字段是存储在null值列表里面的。所以造成了检索时候不匹配的现象,这个还是比较重要的一个点,希望对大家有用。

       声明一下,测试环境是5.7.16版本的MySQL。

    以上就是MySQL中关于null值的一个小问题的详细内容,更多关于MySQL null值的资料请关注IIS7站长之家博文其它相关文章!