《零基础》MySQL NULL 值处理(二十一)

举报
Java李杨勇 发表于 2021/08/04 23:11:44 2021/08/04
【摘要】 MySQL 使用 SQL SELECT 命令及 WHERE 子句来读取数据表中的数据,但是当提供的查询条件字段为 NULL 时,该命令可能就无法正常工作。 为了处理这种情况,MySQL提供了三大运算符: IS NULL: 当列的值是 NULL,此运算符返回 true。IS NOT NULL: 当列的值不为 NULL, 运算符返回 true。<=&...

MySQL 使用 SQL SELECT 命令及 WHERE 子句来读取数据表中的数据,但是当提供的查询条件字段为 NULL 时,该命令可能就无法正常工作。

为了处理这种情况,MySQL提供了三大运算符:

  • IS NULL: 当列的值是 NULL,此运算符返回 true。
  • IS NOT NULL: 当列的值不为 NULL, 运算符返回 true。
  • <=>: 比较操作符(不同于 = 运算符),当比较的的两个值相等或者都为 NULL 时返回 true。

关于 NULL 的条件比较运算是比较特殊的。你不能使用 = NULL 或 != NULL 在列中查找 NULL 值 。

在 MySQL 中,NULL 值与任何其它值的比较(即使是 NULL)永远返回 NULL,即 NULL = NULL 返回 NULL 。

MySQL 中处理 NULL 使用 IS NULL 和 IS NOT NULL 运算符。

注意:


   
  1. select * , columnName1+ifnull(columnName2,0) from tableName;
  2. columnName1,columnName2 为 int 型,当 columnName2 中,有值为 null 时,columnName1+columnName2=null, ifnull(columnName2,0) 把 columnName2 中 null 值转为 0


在命令提示符中使用 NULL 值

以下实例中假设数据库 RUNOOB 中的表 runoob_test_tbl 含有两列 runoob_author 和 runoob_count, runoob_count 中设置插入NULL值。

实例

尝试以下实例:

创建数据表 runoob_test_tbl


  
  1. root@host# mysql -u root -p password;
  2. Enter password:*******
  3. mysql> use RUNOOB;
  4. Database changed
  5. mysql> create table runoob_test_tbl
  6. -> (
  7. -> runoob_author varchar(40) NOT NULL,
  8. -> runoob_count INT
  9. -> );
  10. Query OK, 0 rows affected (0.05 sec)
  11. mysql> INSERT INTO runoob_test_tbl (runoob_author, runoob_count) values ('RUNOOB', 20);
  12. mysql> INSERT INTO runoob_test_tbl (runoob_author, runoob_count) values ('菜鸟教程', NULL);
  13. mysql> INSERT INTO runoob_test_tbl (runoob_author, runoob_count) values ('Google', NULL);
  14. mysql> INSERT INTO runoob_test_tbl (runoob_author, runoob_count) values ('FK', 20);
  15. mysql> SELECT * from runoob_test_tbl;
  16. +---------------+--------------+
  17. | runoob_author | runoob_count |
  18. +---------------+--------------+
  19. | RUNOOB | 20 |
  20. | 菜鸟教程 | NULL |
  21. | Google | NULL |
  22. | FK | 20 |
  23. +---------------+--------------+
  24. 4 rows in set (0.01 sec)

以下实例中你可以看到 = 和 != 运算符是不起作用的:


  
  1. mysql> SELECT * FROM runoob_test_tbl WHERE runoob_count = NULL;
  2. Empty set (0.00 sec)
  3. mysql> SELECT * FROM runoob_test_tbl WHERE runoob_count != NULL;
  4. Empty set (0.01 sec)

查找数据表中 runoob_test_tbl 列是否为 NULL,必须使用 IS NULL 和 IS NOT NULL,如下实例:


  
  1. mysql> SELECT * FROM runoob_test_tbl WHERE runoob_count IS NULL;
  2. +---------------+--------------+
  3. | runoob_author | runoob_count |
  4. +---------------+--------------+
  5. | 菜鸟教程 | NULL |
  6. | Google | NULL |
  7. +---------------+--------------+
  8. 2 rows in set (0.01 sec)
  9. mysql> SELECT * from runoob_test_tbl WHERE runoob_count IS NOT NULL;
  10. +---------------+--------------+
  11. | runoob_author | runoob_count |
  12. +---------------+--------------+
  13. | RUNOOB | 20 |
  14. | FK | 20 |
  15. +---------------+--------------+
  16. 2 rows in set (0.01 sec)

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

原文链接:lyyong.blog.csdn.net/article/details/118629045

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

评论(0

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

全部回复

上滑加载中

设置昵称

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

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

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