sql 语句中的 NULL值

 更新时间:2009年11月04日 00:21:10   作者:  
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,结果是什么呢 ?自己试吧,哈哈。

相关文章

  • sqlserver 2000数据库同步 同步两个SQLServer数据库的内容

    sqlserver 2000数据库同步 同步两个SQLServer数据库的内容

    程序代码可以有版本管理CVS进行同步管理,可是数据库同步就非常麻烦,只能自己改了一个后再去改另一个,如果忘记了更改另一个经常造成两个数据库的结构或内容上不一致.
    2010-05-05
  • sql server中错误日志errorlog的深入讲解

    sql server中错误日志errorlog的深入讲解

    很多时候诊断SQLSERVER问题都需要看SQLSERVER的错误日志,所以下面这篇文章主要给大家介绍了关于sql server中错误日志errorlog的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2018-10-10
  • sql server中批量插入与更新两种解决方案分享(存储过程)

    sql server中批量插入与更新两种解决方案分享(存储过程)

    对于sql 来说操作集合类型(一行一行)是比较麻烦的一件事,而一般业务逻辑复杂的系统或项目都会涉及到集合遍历的问题,通常一些人就想到用游标,这里我列出了两种方案,供大家参考
    2012-05-05
  • SQL Server2022安装教程的实现步骤(图文教程)

    SQL Server2022安装教程的实现步骤(图文教程)

    在日常的工作中,sql server作为一款常用的数据库管理系统,安装与配置就显得非常重要,本文主要介绍了SQL Server2022安装教程的实现步骤,感兴趣的可以了解一下
    2023-09-09
  • SQL Server Page结构深入分析

    SQL Server Page结构深入分析

    这篇文章主要介绍了SQL Server Page结构的详细分析,从概念,原理等方便做了详细说明,一起来学习下。
    2017-12-12
  • EXEC(EXECUTE)函数访问INSERTED或DELETED的内部临时触发表

    EXEC(EXECUTE)函数访问INSERTED或DELETED的内部临时触发表

    近段时间,MS SQL方面,一直需要开发动态方面的存储过程或是触发器以及表函数。因为程序设计一开始就是让用户动态添或是删除一个表的字段,然而这个表的相关存储过程或是触发器以及为报表准备的表函数也会随之这个表的字段变化而变化
    2012-01-01
  • SQL Server跨库/服务器查询及拓展知识点

    SQL Server跨库/服务器查询及拓展知识点

    因为业务要求,之前碰到需要跨服务器操作另一个数据库的数据,这里总结下,这篇文章主要给大家介绍了关于SQL Server跨库/服务器查询及拓展知识点的相关资料,需要的朋友可以参考下
    2023-11-11
  • SQL Server中通用数据库角色权限的处理详解

    SQL Server中通用数据库角色权限的处理详解

    这篇文章主要给大家介绍了关于SQL Server中通用数据库角色权限处理的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-10-10
  • SQL 将一列拆分成多列的三种方法

    SQL 将一列拆分成多列的三种方法

    这篇文章主要介绍了SQL 将一列拆分成多列的方法,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • 基于Python的SQL Server数据库实现对象同步轻量级

    基于Python的SQL Server数据库实现对象同步轻量级

    这篇文章主要介绍了基于Python的SQL Server数据库对象同步轻量级实现方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-06-06

最新评论