MySQL中的NULL值问题

举例数据库:

mysql> SELECT * FROM PET;
+----------+--------+---------+------+------------+------------+
| name     | owner  | species | sex  | birth      | death      |
+----------+--------+---------+------+------------+------------+
| Fluffy   | Harold | cat     | f    | 1993-02-04 | NULL       |
| Claws    | Gwen   | cat     | m    | 1994-03-17 | NULL       |
| Buffy    | Harold | dog     | f    | 1989-05-13 | NULL       |
| Fang     | Benny  | dog     | m    | 1990-08-27 | NULL       |
| Chirpy   | Gwen   | bird    | f    | 1998-09-11 | NULL       |
| Whistler | Gwen   | bird    | NULL | 1997-12-09 | NULL       |
| Slim     | Benny  | snake   | m    | 1996-04-29 | NULL       |
| Bowser   | Diane  | dog     | m    | 1979-08-31 | 1995-07-29 |
+----------+--------+---------+------+------------+------------+

1. NULL值不能用于比较,因为任何值和NULL值比较永远是NULL

mysql> SELECT 1 = NULL, 1 <> NULL, 1 < NULL, 1 > NULL, NULL = NULL;
+----------+-----------+----------+----------+-------------+
| 1 = NULL | 1 <> NULL | 1 < NULL | 1 > NULL | NULL = NULL |
+----------+-----------+----------+----------+-------------+
|     NULL |      NULL |     NULL |     NULL |        NULL |
+----------+-----------+----------+----------+-------------+

所以,寻找NULL值不能使用比较运算符,应该使用IS [NOT] NULL:

mysql> SELECT * FROM PET WHERE DEATH = NULL;
Empty set (0.01 sec)

mysql> SELECT * FROM PET WHERE DEATH IS NULL;
+----------+--------+---------+------+------------+-------+
| name     | owner  | species | sex  | birth      | death |
+----------+--------+---------+------+------------+-------+
| Fluffy   | Harold | cat     | f    | 1993-02-04 | NULL  |
| Claws    | Gwen   | cat     | m    | 1994-03-17 | NULL  |
| Buffy    | Harold | dog     | f    | 1989-05-13 | NULL  |
| Fang     | Benny  | dog     | m    | 1990-08-27 | NULL  |
| Chirpy   | Gwen   | bird    | f    | 1998-09-11 | NULL  |
| Whistler | Gwen   | bird    | NULL | 1997-12-09 | NULL  |
| Slim     | Benny  | snake   | m    | 1996-04-29 | NULL  |
+----------+--------+---------+------+------------+-------+

2. NULL值在ORDER BY或者GROUP BY子句中按照相同对待

mysql> SELECT * FROM PET ORDER BY DEATH;
+----------+--------+---------+------+------------+------------+
| name     | owner  | species | sex  | birth      | death      |
+----------+--------+---------+------+------------+------------+
| Fluffy   | Harold | cat     | f    | 1993-02-04 | NULL       |
| Claws    | Gwen   | cat     | m    | 1994-03-17 | NULL       |
| Buffy    | Harold | dog     | f    | 1989-05-13 | NULL       |
| Fang     | Benny  | dog     | m    | 1990-08-27 | NULL       |
| Chirpy   | Gwen   | bird    | f    | 1998-09-11 | NULL       |
| Whistler | Gwen   | bird    | NULL | 1997-12-09 | NULL       |
| Slim     | Benny  | snake   | m    | 1996-04-29 | NULL       |
| Bowser   | Diane  | dog     | m    | 1979-08-31 | 1995-07-29 |
+----------+--------+---------+------+------------+------------+

3. 0和' '不是NULL,完全可能插入到NOT NULL的列里

将PET表中的name字段改为NOT NULL,然后新加记录:

mysql> ALTER TABLE PET MODIFY COLUMN name VARCHAR(20) NOT NULL;
Query OK, 0 rows affected (0.10 sec)

mysql> DESCRIBE PET;
+---------+-------------+------+-----+---------+-------+
| Field   | Type        | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| name    | varchar(20) | NO   |     | NULL    |       |
| owner   | varchar(20) | YES  |     | NULL    |       |
| species | varchar(20) | YES  |     | NULL    |       |
| sex     | char(1)     | YES  |     | NULL    |       |
| birth   | date        | YES  |     | NULL    |       |
| death   | date        | YES  |     | NULL    |       |
+---------+-------------+------+-----+---------+-------+
6 rows in set (0.00 sec)

mysql> INSERT INTO PET VALUES(NULL, 'Matthew', 'cat', 'f', '2010-01-04', NULL);
ERROR 1048 (23000): Column 'name' cannot be null

mysql> INSERT INTO PET VALUES('', 'Matthew', 'cat', 'f', '2010-01-04', NULL);
Query OK, 1 row affected (0.01 sec)

mysql> INSERT INTO PET VALUES(0, 'Matthew', 'cat', 'f', '2010-01-04', NULL);
Query OK, 1 row affected (0.01 sec)

4. 在MySQL中,0和NULL意味着FALSE,其他值意味着TRUE

mysql> SELECT * FROM PET WHERE 1 <> 1;
Empty set (0.00 sec)

mysql> SELECT * FROM PET WHERE 1 <> NULL;
Empty set (0.00 sec)

5. 空值不占用空间,但NULL值占用空间

举个例子:假设你有一个杯子,空值代表杯子是真空的,NULL值代表杯子中装满了空气

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值