条件 NOT NULL 情况 MySQL?
mysqlmysqli database
对于条件 NOT NULL 情况,您不需要使用 <> 和 = 运算符。您需要使用 IS NULL 和 IS NOT NULL 属性,因为 NULL 在 MySQL 中是一种特殊情况。
为了理解条件 NOT NULL 情况,让我们创建一个表。创建表的查询如下:
mysql> create table ConditionalNotNullDemo -> ( -> Id int NOT NULL AUTO_INCREMENT, -> SendMessage longtext, -> PRIMARY KEY(Id) -> ); Query OK, 0 rows affected (0.62 sec)
使用 insert 命令在表中插入一些记录。 查询语句如下:
mysql> insert into ConditionalNotNullDemo(SendMessage) values(NULL); Query OK, 1 row affected (0.16 sec) mysql> insert into ConditionalNotNullDemo(SendMessage) values('Hi'); Query OK, 1 row affected (0.15 sec) mysql> insert into ConditionalNotNullDemo(SendMessage) values('Hello'); Query OK, 1 row affected (0.20 sec) mysql> insert into ConditionalNotNullDemo(SendMessage) values(NULL); Query OK, 1 row affected (0.18 sec)
使用 select 语句显示表中的所有记录。查询如下:
mysql> select *from ConditionalNotNullDemo;
输出结果如下:
+----+-------------+ | Id | SendMessage | +----+-------------+ | 1 | NULL | | 2 | Hi | | 3 | Hello | | 4 | NULL | +----+-------------+ 4 rows in set (0.00 sec)
这里是 IS NULL 和 IS NOT NULL 属性的演示。
案例1:如果要过滤所有 NULL 消息,则使用 IS NULL 属性。查询如下:
mysql> select *from ConditionalNotNullDemo where SendMessage IS NULL;
输出结果如下:
+----+-------------+ | Id | SendMessage | +----+-------------+ | 1 | NULL | | 4 | NULL | +----+-------------+ 2 rows in set (0.00 sec)
案例 2:使用 IS NOT NULL 属性。如果要显示除 NULL 消息之外的所有有效消息,可以使用 IS NULL 属性。查询如下:
mysql> select *from ConditionalNotNullDemo where SendMessage IS NOT NULL;
输出结果如下:
+----+-------------+ | Id | SendMessage | +----+-------------+ | 2 | Hi | | 3 | Hello | +----+-------------+ 2 rows in set (0.03 sec)