sql 语句中的 NULL值

时间:2024-01-14 06:41:16 

今天写了这样的代码


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,结果是什么呢 ?自己试吧,哈哈。

标签:sql,NULL
0
投稿

猜你喜欢

  • python安装pil库方法及代码

    2021-10-22 16:55:24
  • ServerXMLHTTP的setTimeouts超时设置

    2010-01-02 20:38:00
  • python小白切忌乱用表达式

    2021-08-11 19:57:11
  • js自动闭合html标签(自动补全html标记)

    2023-08-25 07:06:35
  • 详解Mysql多表联合查询效率分析及优化

    2024-01-23 00:59:29
  • SQL Server 数据文件收缩和查看收缩进度的步骤

    2024-01-12 19:34:03
  • 快速一键生成Python爬虫请求头

    2022-05-21 01:00:53
  • javascript代码实现简易计算器

    2024-04-16 08:57:46
  • Python创建文件夹与文件的快捷方法

    2022-08-31 19:50:49
  • volatile保证可见性及重排序方法

    2022-07-22 03:14:59
  • Vue如何引入远程JS文件

    2023-07-02 16:34:13
  • python实现在函数中修改变量值的方法

    2023-12-15 04:15:02
  • 如何解决在Azure上部署Sqlserver网络访问不了

    2024-01-14 07:47:38
  • Python编程通过懒属性提升性能

    2022-04-01 09:48:43
  • python中enumerate函数遍历元素用法分析

    2021-08-07 10:07:18
  • python3 写一个WAV音频文件播放器的代码

    2023-04-09 05:06:36
  • ubuntu下搭建Go语言(golang)环境

    2024-05-11 09:08:47
  • Python生成九宫格图片的示例代码

    2023-03-16 20:29:38
  • 压缩技术给SQL Server备份文件瘦身

    2024-01-26 05:10:23
  • js判断数组key是否存在(不用循环)的简单实例

    2024-04-17 10:40:35
  • asp之家 网络编程 m.aspxhome.com