SQL NULL:空值
表的字段默认允许存放 NULL 值,这意味着,您在插入记录或者更新记录时,可以不为该字段指定值,此时该字段将存储 NULL 值。
在查询结果中,空值将显示为空白或者 NULL,如下所示:
sir_name | name | marks |
|---|---|---|
TYAGI | SEEMA | NULL |
SINGH | RAMAN | 5.5 |
SHARMA | AMAR | NULL |
JAISWAL | VICKY | 6.2 |
条和第三条记录的 MARKS 字段就出现了 NULL 值。
语法
在创建数据表时可以指定某个字段是否允许为 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。
示例
在选取数据时,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网站站点" rel="nofollow" />
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 |
+----+----------------+-----+---------+---------+
- 随机文章
- 核心危机(核心危机魔石合成攻略)
- 风儿(风儿轻轻的吹)
- 饿了么红包怎么用(饿了么红包怎么用微信支付)
- 儿童教育文章(儿童教育)
- 光遇花手先祖位置(安卓光遇手花先祖)
- 广州4a广告公司(广州4a广告公司创意总监年薪)
- 抖音卡(抖音卡顿怎么解决)
- xboxones(xboxone手柄怎么配对主机)
- 兵马俑(兵马俑介绍和历史背景)
- 陈武简历
- 帆船比赛(帆船比赛视频)
- 海猫鸣泣之时游戏(海猫鸣泣之时游戏在哪玩)
- 韩国媳妇和小雪(韩国媳妇和小雪的父亲工资是多少)
- 儋州市第二中学(儋州市第二中学录取分数线)
- 鬼泣5攻略(鬼泣5攻略第三关怎么跳)
- 地球日主题(2020年世界地球日主题)
- 和柳亚子(和柳亚子先生于田)
- yy魔兽(yy魔兽世界)
- 充值卡代理(充值卡代理加盟)
- 东天目山(东天目山景区)
- 蝙蝠给人类的一封信(蝙蝠给人类的一封信)
- 大松电饭煲(美的大松电饭煲)
- 观音普门品(观音普门品念诵全文)
- 哈利波特官网(哈利波特官网在哪里)
- 骇客神条(骇客神条怎么辨别真假)
- 杜星霖(杜星霖图片)
- 查传倜(查传倜个人生活)
- 广州晓港公园(广州晓港公园正门图片)
- 常州天宁寺(常州天宁寺求什么灵验)
- 河源巴伐利亚(河源巴伐利亚庄园)
