SQL学习之Null值

参考源

SQL null 值

SQL 中, Null空字符串, 都不相同。是指为未定义或是未知的值

默认地,表的列可以存放 NULL 值

SQL 中的 NULL 值只有两种操作:is nullis 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 NULLIS 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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值