is not NULL 和 != NULL 的区别

SQL server中 is not NULL 和 != NULL 的区别

NULL 表示的是什么都没有,它与空字符串、0 这些是不等价的,是不能用于比较的! 如: = NULL 、 NULL = '' 得到的结果为 false,判断 NULL 必须使用 IS NULL 或 IS NOT NULL 进行判断。

- 创建数据库

  --创建数据库database_1
  CREATE DATABASE database_1

- 创建表

CREATE TABLE database_1.DBO.Table_1(
	[Column] CHAR(5),
	[Values] CHAR(5)
	)

- 插入值

  INSERT INTO Table_1 ([Column],[Values])values
			 ('列1','值1'),
			 ('列2','值2'),
			 ('列3',null),
			 ('列4',null),
			 ('列5',null)

-完成后的表的内容

alt

-测试 !=NULL

 SELECT *FROM DBO.Table_1 WHERE [Values] != NULL;
查询结果

alt

-测试 is not NULL

   SELECT *FROM DBO.Table_1 WHERE [Values] IS NOT NULL;
查询结果

alt

-结论

默认情况下,推荐使用 IS NOT NULL去判断,因为SQL默认情况下对!= Null的判断会永远返回0行,但没有语法错误。

如果你一定想要使用!= Null来判断,需要加上这个语句:

set ANSI_NULLS off

SELECT *FROM DBO.Table_1 WHERE [Values] != NULL set ANSI_NULLS off;

这时你会发现IS NOT NULL 和 != null 是等效的。

全部评论

相关推荐

合适才能收到offe...:招聘上写这些态度傲慢的就别继续招呼了,你会发现hr和面试官挺神的,本来求职艰难就可能影响一些心态了,你去这种公司面试的话,整个心态会炸的。
点赞 评论 收藏
分享
评论
2
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务