当前位置: 首页 > 图文教程 > 数据库 > MSSQL > sql 语句中的 NULL值

MSSQL
开源MySQL公司停止提供企业版源代码tar包
细化解析:MySQL+Webmin轻松创建数据库
用mysql做站点时怎样记录未知错误的发生
SQL数据库操作类
如何利用SQL Server数据库快照形成报表
SQL Server中应当怎样得到自动编号字段
SQL Server数据库连接中常见的错误分析
详细讲解SQL Server数据库的文件恢复技术
轻松掌握SQL Server数据库的六个实用技巧
SQL Server数据库涉及到的数据仓库概念
深入了解SQL Server 2008 商业智能平台
剖析SQL Server 事务日志的收缩和截断
如何在不同版本的SQL Server中存储数据
怎样缩小SQL Server数据库的日志文件
SQL Server中两种修改对象所有者的方法
轻松掌握SQL Server存储过程的命名标准
怎样从旧版本SQL Server中重新存储数据
快速掌握如何使用SQL Server来过滤数据
教你快速掌握两个SQL Server的维护技巧
有效地使用 SQL事件探查器的提示和技巧

MSSQL 中的 sql 语句中的 NULL值


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-10   浏览: 209 ::
收藏到网摘: n/a

sql 语句中的 NULL值 ,需要的朋友可以看看。 今天写了这样的代码
复制代码 代码如下:

  DECLARE @atr NVARCHAR(20)
  SET @atr = NULL
  IF(@atr = NULL)
  BEGIN
  PRINT 1
  END
  原本是想打印出1的。但是没有。 把 代码修改成如下:
  DECLARE @atr NVARCHAR(20)
  SET @atr = NULL
  IF(@atr IS NULL)
  BEGIN
  PRINT 1
  END

  这样就正确打印出1了。
  然后自己有做了如下的修改,把if语句修改成
复制代码 代码如下:

  IF(NULL = NULL)
  BEGIN
   PRINT 1
  END

  结果:不会打印出1
  由此我们可以总结sql语句中的NULL值和任何值在做 ”=“运算的时候都不会相等。 要用" IS NULL " 做是否是NULL值的判断。
  我们还可以用函数 ISNULL(@str,0) = 0 来判断 变量是否是NULL值。
  小问题,记录一下,强化记忆,善于总结,不走冤枉路。
================================================================================
  补充:NULL 与 "+" 运算符。
  “+” 可以用来做字符串的连接,还可以做加法运算,那么NULL值和字符串做“+”会是什么样的结果?我写了下面的验证程序:
  
复制代码 代码如下:

  DECLARE @str NVARCHAR(200)
  DECLARE @str1 NVARCHAR(200)
  DECLARE @str2 NVARCHAR(200)
  SET @str = NULL
  SET @str1 = 'You look pretty today'
  SET @str2 = @str + @str1
  PRINT @str2

  结果什么东西都没有打印出来,为什么呢 ?我们测试一下@str2现在是何值?
  IF(@str2 IS NULL)
  PRINT 1
  结果打印出1,于是我们可以猜测NULL和任何类型做“+”运算结果仍为NULL值
  
  再写一个NULL和INT类型做"+"的验证程序:
复制代码 代码如下:

  DECLARE @num INT
  DECLARE @num1 INT
  DECLARE @num2 INT
  SET @num = 1
  SET @num1 = 2
  SET @num2 = @num + @num1
  PRINT @num2

  结果打印出3,将红色加粗部分换成 SET @num = NULL,结果是什么呢 ?自己试吧,哈哈。