365Tools
    发布时间:2024-04-05 14:30:01
在 SQL 中,关键字 NULL 用来表示缺失的值,也即空值,或者没有值。NULL 值不等同于零值,也不等同于包含空格的字段,理解这一点非常重要。| sir_name | name | marks | 
|---|---|---|
| TYAGI | SEEMA | NULL | 
| SINGH | RAMAN | 5.5 | 
| SHARMA | AMAR | NULL | 
| JAISWAL | VICKY | 6.2 | 
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。
+----+----------------+-------------------------+-----+-------+---------+---------+ | 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 | 365工具网 | http://www.365tools.cn/ | 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 | +----+----------------+-------------------------+-----+-------+---------+---------+
SELECT id, name, age, uv, country FROM website WHERE url IS NOT NULL;执行结果:
+----+-------------+-----+--------+---------+ | id | name | age | uv | country | +----+-------------+-----+--------+---------+ | 1 | 百度 | 20 | 5010.5 | CN | | 3 | 365工具网 | 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 | +----+-------------+-----+--------+---------+
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 | +----+----------------+-----+---------+---------+