二十五岁时我们都一样愚蠢、多愁善感,喜欢故弄玄虚,可如果不那样的话,五十岁时也就不会如此明智。
标题:SQL NULL 值
SQL 中,
NULL
与 空字符串, 零 都不相同。是指为未定义或是未知的值默认地,表的列可以存放 NULL 值
SQL 中的
NULL
值只有两种操作:IS NULL
和IS NOT NULL
操作符SQL NULL 值构成原因
造成某一列成为 NULL 的因素可能是:
- 值不存在
- 值未知
- 列不可用
SQL NULL 值
如果表中的某个列是可选的,那么我们可以在不向该列添加值的情况下插入新记录或更新已有的记录
SQL 数据库会自动将该该字段将以 NULL 值保存
NULL 值的处理方式与其它值不同: 无法比较 NULL 和 0;它们是不等价的
演示数据
先在 MySQL 数据库运行下面的语句创建测试数据
CREATE DATABASE IF NOT EXISTS twle default character set utf8mb4 collate utf8mb4_unicode_ci; USE twle; DROP TABLE IF EXISTS `lession`; CREATE TABLE `lession` ( id int(11) NOT NULL PRIMARY KEY AUTO_INCREMENT, name varchar(32) default '', views int(11) NOT NULL default '0', created_at DATETIME ); INSERT INTO lession(id,name,views,created_at) VALUES (1, 'Python 基础教程',981,'2017-04-18 13:52:03'), (2, 'Scala 基础教程',73,'2017-04-18 16:03:32'), (3, 'Ruby 基础教程',199,'2017-05-01 06:16:14'), (4, NULL, 105,'2017-05-02 18:03:16');使用
SELECT * FROM lession;
运行结果如下+----+---------------------+-------+---------------------+ | id | name | views | created_at | +----+---------------------+-------+---------------------+ | 1 | Python 基础教程 | 981 | 2017-04-18 13:52:03 | | 2 | Scala 基础教程 | 73 | 2017-04-18 16:03:32 | | 3 | Ruby 基础教程 | 199 | 2017-05-01 06:16:14 | | 4 | NULL | 105 | 2017-05-02 18:03:16 | +----+---------------------+-------+---------------------+总共有 4 条记录
SQL 的 NULL 值处理
假定我们在设计表
lession
时将name
字段设置成可选的也就是说如果在
name
列插入一条不带值的记录,name
列会使用NULL
值现在问题来了,我们如何测试
NULL
值呢?NULL 值无法使用比较运算符来测试 NULL 值,比如
=
、<
或<>
NULL 值的测试必须使用
IS NULL
和IS NOT NULL
操作符SQL
IS NULL
操作符我们要如何选择那些
name
列中带有NULL
值的记录呢?这时候
IS NULL
操作符就可以派上用场了,它用于判断某个值或列为NULL
值SELECT * FROM lession WHERE name IS NULL;运行结果如下
mysql> SELECT * FROM lession WHERE name IS NULL; +----+------+-------+---------------------+ | id | name | views | created_at | +----+------+-------+---------------------+ | 4 | NULL | 105 | 2017-05-02 18:03:16 | +----+------+-------+---------------------+最佳实战
在 SQL 中,始终使用
IS NULL
来查找NULL
值SQL IS NOT NULL
那我们又要如何选择那些
name
字段不为NULL
值的记录呢?
IS NOT NULL
操作符就派上用场了,它用于判断那些值或者字段列不为NULL
值SELECT * FROM lession WHERE name IS NOT NULL;运行结果如下
mysql> SELECT * FROM lession WHERE name IS NOT NULL; +----+---------------------+-------+---------------------+ | id | name | views | created_at | +----+---------------------+-------+---------------------+ | 1 | Python 基础教程 | 981 | 2017-04-18 13:52:03 | | 2 | Scala 基础教程 | 73 | 2017-04-18 16:03:32 | | 3 | Ruby 基础教程 | 199 | 2017-05-01 06:16:14 | +----+---------------------+-------+---------------------+NULL 值最佳实战
如非必要,设计表时不要将某个字段设置为 NULL