25. SQL--null
1. 前言
在 SQL 中,关键字 NULL 用来表示缺失的值,也即空值,或者没有值。NULL 值不等同于零值,也不等同于包含空格的字段,理解这一点非常重要。
表的字段默认允许存放 NULL 值,这意味着,您在插入记录或者更新记录时,可以不为该字段指定值,此时该字段将存储 NULL 值。
在查询结果中,空值将显示为空白或者 NULL,如下所示:
sir_name | name | marks |
---|---|---|
TYAGI | SEEMA | NULL |
SINGH | RAMAN | 5.5 |
SHARMA | AMAR | NULL |
JAISWAL | VICKY | 6.2 |
第一条和第三条记录的 MARKS 字段就出现了 NULL 值。
2. 语法
在创建数据表时可以指定某个字段是否允许为 NULL,基本语法如下:
create table website (
id int not null auto_increment,
name varchar(20) not null,
url varchar(30),
age tinyint unsigned not null,
alexa int unsigned not null,
uv float default '0',
country char(3) not null default '',
primary key (`id`)
);
not null 关键字表示不允许该字段为空值,在插入或者更新记录时必须为该字段指定一个具体的值。url 和 uv 两个字段没有使用 not null 关键字,这意味着它们保持默认,也即允许为 null。注意,uv 字段指定了默认值 0,如果不为该字段提供值,它的值将是 0;url 字段没有指定默认值,如果不为该字段提供值,它的值将是 null。
3. 示例
在选取数据时,null 值可能会导致一些问题,因为 null 值和其它任何值比较的结果都是未知的,所以包含 null 值的记录始终不能被筛选。
我们不能使用 =、<、> 等比较运算符来检测 null 值,而必须使用 is null 或者 is not null 关键字来检测 null 值。
现在有一个包含如下记录的 website 表:
+----+----------------+-------------------------+-----+-------+---------+---------+ | id | name | url | age | alexa | uv | country | +----+----------------+-------------------------+-----+-------+---------+---------+ | 1 | 百度 | https://www.baidu.com/ | 20 | 4 | 5010.5 | CN | | 2 | 淘宝 | NULL | 20 | 8 | 3996.75 | CN | | 3 | C语言中文网 | http://c.biancheng.net/ | 12 | 7923 | 11.62 | CN | | 4 | Google | https://www.google.com/ | 23 | 1 | 36474 | US | | 5 | GitHub | https://github.com/ | 15 | 95 | 216.3 | US | | 6 | Stack Overflow | NULL | 15 | 48 | 592.2 | US | | 7 | Yandex | http://www.yandex.ru/ | 11 | 53 | 591.82 | RU | | 8 | VK | https://vk.com/ | 23 | 23 | 1206 | RU | +----+----------------+-------------------------+-----+-------+---------+---------+
下面是 is not null 关键字的用法:
select id, name, age, uv, country
from website
where url is not null;
执行结果:
+----+-------------+-----+--------+---------+ | id | name | age | uv | country | +----+-------------+-----+--------+---------+ | 1 | 百度 | 20 | 5010.5 | CN | | 3 | C语言中文网 | 12 | 11.62 | CN | | 4 | Google | 23 | 36474 | US | | 5 | GitHub | 15 | 216.3 | US | | 7 | Yandex | 11 | 591.82 | RU | | 8 | VK | 23 | 1206 | RU | +----+-------------+-----+--------+---------+
再如,下面是 IS NULL 关键字的用法:
select id, name, age, uv, country from website where url is null;
执行结果:
+----+----------------+-----+---------+---------+ | id | name | age | uv | country | +----+----------------+-----+---------+---------+ | 2 | 淘宝 | 20 | 3996.75 | CN | | 6 | Stack Overflow | 15 | 592.2 | US | +----+----------------+-----+---------+---------+
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)