如何在 MySQL 中检查列值是否为 NULL 或具有默认值?


您可以使用 IFNULL() 的概念来实现。让我们首先创建一个表 -

mysql> create table DemoTable
(
   Id int NOT NULL AUTO_INCREMENT PRIMARY KEY,
   Name varchar(100) DEFAULT 'Larry',
   Age int DEFAULT NULL
);
Query OK, 0 rows affected (0.73 sec)

使用 INSERT 命令在表中插入记录 -

mysql> insert into DemoTable(Name,Age) values('John',23);
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable values();
Query OK, 1 row affected (0.34 sec)
mysql> insert into DemoTable(Name) values('David');
Query OK, 1 row affected (0.20 sec)
mysql> insert into DemoTable(Age) values(24);
Query OK, 1 row affected (0.13 sec)

以下是使用 SELECT 语句从表中显示所有记录的查询 -

mysql> select *from DemoTable;

这将产生以下输出 -

+----+-------+------+
| Id | Name  | Age  |
+----+-------+------+
| 1  | John  | 23   |
| 2  | Larry | NULL |
| 3  | David | NULL |
| 4  | Larry | 24   |
+----+-------+------+
4 rows in set (0.00 sec)

以下是检查 MySQL 列值是否为 NULL 或具有默认值的查询。

mysql> select *from DemoTable WHERE IFNULL(Name, DEFAULT(Name)) <> DEFAULT(Name);

这将产生以下输出 -

+----+-------+------+
| Id | Name  | Age  |
+----+-------+------+
| 1  | John  | 23   |
| 3  | David | NULL |
+----+-------+------+
2 rows in set (0.00 sec)

更新日期:2019 年 7 月 30 日

487 次浏览

开启您的职业生涯

完成课程可获得认证

开始
广告