参考源
- 简单教程
- 菜鸟教程
SQL null 值
SQL 中, Null
与 空字符串
, 零
都不相同。是指为未定义或是未知的值
默认地,表的列可以存放 NULL 值
SQL 中的 NULL 值只有两种操作:is null
和 is not null
操作符
如果表中的某个列是可选的,那么我们可以在不向该列添加值的情况下插入新记录或更新已有的记录
SQL 数据库会自动将该该字段将以 Null
值保存
NULL 值的处理方式与其它值不同: 无法比较 NULL 和 0;它们是不等价的
SQL NULL 值构成原因
- 值不存在
- 值未知
- 列不可用
示例数据
CREATE DATABASE IF NOT EXISTS hardy_db default character set utf8mb4 collate utf8mb4_0900_ai_ci;
USE hardy_db;
DROP TABLE IF EXISTS lesson;
CREATE TABLE lesson (
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 lesson(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');
SQL 的 NULL 值处理
NULL
值无法使用比较运算符来测试 NULL
值,比如 =
、<
或 <>
NULL
值的测试必须使用 IS NULL
和 IS NOT NULL
操作符
SQL IS NULL 操作符
SELECT * FROM lesson WHERE name IS NULL;
运行结果如下
mysql> SELECT * FROM lesson WHERE name IS NULL;
+----+------+-------+---------------------+
| id | name | views | created_at |
+----+------+-------+---------------------+
| 4 | NULL | 105 | 2017-05-02 18:03:16 |
+----+------+-------+---------------------+
SQL IS NOT NULL 操作符
SELECT * FROM lesson WHERE name IS NOT NULL;
运行结果如下
mysql> SELECT * FROM lesson 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