标题MySQL中,!=NULL和IS NOT NULL的区别
1、!=null
!=NULL表示不等于NULL,它可以检查一个字段是否有值,如果该字段有值,那么返回TRUE,否则返回FALSE。
SELECT * FROM student WHERE name != NULL; 现在要查找所有name不为空的学生
以上语句将不会返回任何结果。在MySQL中,NULL代表未知或不存在的值,如果使用!=NULL检查一个字段,那么该字段的值不为NULL时,返回的结果为TRUE,但是当该字段的值为NULL时,结果不是FALSE,而是未知,因此我们无法确定它是否等于某个值。
2、IS NOT NULL
IS NOT NULL表示不是空的,它可以确定一个字段是否为空,如果该字段有值,那么返回TRUE,否则返回FALSE。
SELECT * FROM student WHERE name IS NOT NULL; 该语句将返回所有name字段不为空的学生记录。
3、使用区别
!=NULL用于检查字段是否不等于NULL,而IS NOT NULL用于检查字段是否不为空。以下是两个语句的区别:
SELECT * FROM student WHERE name != NULL; -- 无结果返回
SELECT * FROM student WHERE name IS NOT NULL; -- 返回所有name字段不为空的学生记录
4、测试结果
有表名为persons的信息表
|name| age |
|张三| 20 |
| 李四 | 22 |
| 王五 | null|
-- 使用!=NULL检查age字段是否不为空
SELECT name FROM person WHERE age != NULL; -- 无结果返回
-- 使用IS NOT NULL检查age字段是否不为空
SELECT name FROM person WHERE age IS NOT NULL; -- 返回张三和李四
5、结论
1、!=NULL表示不等于NULL,用于检查字段是否不等于NULL;而IS NOT NULL表示不为空,用于检查字段是否不为空。
2、两者的区别在于,!=NULL无法处理NULL值,不能正确地确定一个字段是否为空,所以应该使用IS NOT NULL来检查一个字段是否为空。