MySql Null注意事项

本是古典 何须时尚 2022-08-22 14:16 434阅读 0赞

MySql Null注意事项

在mysql中使用null值时有很多注意事项,踩过不少坑,在此总结以下。(IFNULL()函数可以将NULL值转换成你想要的值,用法为:IFNULL(expr1,expr2))

计算

mysql中所有与null计算的结果均为null

  1. mysql> SELECT NULL, 1+NULL,1-NULL,1*NULL,1/NULL, CONCAT('Invisible',NULL),SUBSTRING('12345',1,NULL),REPLACE('abc','c',NULL);
  2. +------+--------+--------+--------+--------+--------------------------+---------------------------+-------------------------+
  3. | NULL | 1+NULL | 1-NULL | 1*NULL | 1/NULL | CONCAT('Invisible',NULL) | SUBSTRING('12345',1,NULL) | REPLACE('abc','c',NULL) |
  4. +------+--------+--------+--------+--------+--------------------------+---------------------------+-------------------------+
  5. | NULL | NULL | NULL | NULL | NULL | NULL | NULL | NULL |
  6. +------+--------+--------+--------+--------+--------------------------+---------------------------+-------------------------+
  7. 1 row in set (0.00 sec)

统计

当使用DISTINCT, GROUP BY, 或者 ORDER BY 时所有的NULL值都看作相等的。

当使用一些统计函数时,mysql会忽略NUll的值,比如count(),min(),sum().

创建测试表a,并插入如下数据:

  1. mysql> select * from a; +----+------+
  2. | id | t | +----+------+
  3. | 1 | NULL |
  4. | 2 | 1 |
  5. | 3 | 2 | +----+------+
  6. 3 rows in set (0.00 sec)

执行如下结果,查看值:

  1. mysql> select count(*),count(t),sum(t),min(t) from a; +----------+----------+--------+--------+
  2. | count(*) | count(t) | sum(t) | min(t) | +----------+----------+--------+--------+
  3. | 3 | 2 | 3 | 1 | +----------+----------+--------+--------+
  4. 1 row in set (0.00 sec)

从结果可以看出,在使用count(t)时没有将null的值计算在内;使用sum(t)时也不是以1+2+null来计算的,而是忽略了NULL的值。

排序

在使用order by对存在NULL值的列进行排序时,在ASC情况下NULL值会排在前面,使用DESC时NULL会排在后面。
以上面的表为例:

  1. mysql> select * from a order by t; +----+------+
  2. | id | t | +----+------+
  3. | 1 | NULL |
  4. | 2 | 1 |
  5. | 3 | 2 | +----+------+
  6. 3 rows in set (0.00 sec)
  7. mysql> select * from a order by t desc; +----+------+
  8. | id | t | +----+------+
  9. | 3 | 2 |
  10. | 2 | 1 |
  11. | 1 | NULL | +----+------+
  12. 3 rows in set (0.00 sec)

在oracle中NULL值排序和mysql一样,但是可以使用nulls first,nulls last来控制排序前后。

比较

在对null值进行比较时,只能使用 is 、not is、<=>来进行,而不能使用=、<>、>、<等运算符号。mysql中空字符串和NULL值不是等价的。
在a表中插入一条新值:

  1. mysql> insert into a values (NULL,'');
  2. Query OK, 1 row affected (0.06 sec)

再查看如下语句:

  1. mysql> select * from a where t = null;
  2. Empty set (0.00 sec)
  3. mysql> select * from a where t is null; +----+------+
  4. | id | t | +----+------+
  5. | 1 | NULL | +----+------+
  6. 1 row in set (0.00 sec)
  7. mysql> select * from a where t = ''; +----+------+
  8. | id | t | +----+------+
  9. | 4 | | +----+------+
  10. 1 row in set (0.00 sec)
  11. mysql> select * from a where t <=> null; +----+------+
  12. | id | t | +----+------+
  13. | 1 | NULL | +----+------+
  14. 1 row in set (0.00 sec)

插入

从上面一个例子中的插入语句我们可以看到,在insert语句中插入NULL值时,实际结果不一定是NULL。

mysql在以下两种情况下,插入NULL值时,实际插入的结果不为NULL:

  • 向自增(AUTO_INCREMENT)字段中插入NULL值,实际插入的是自增的下一个值。
  • 向 TIMESTAMP字段中插入NULL值,实际插入的是当前时间。

发表评论

表情:
评论列表 (有 0 条评论,434人围观)

还没有评论,来说两句吧...

相关阅读

    相关 mysql注意事项

    1. 如果GROUP BY 的列没有索引,产生临时表. 2. 如果GROUP BY时,SELECT的列不止GROUP BY列一个,并且GROUP BY的列不是主键 ,