如何在 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)
广告