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