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,结果是什么呢 ?自己试吧,哈哈。
相关推荐
-
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(N
-
在 SQL 语句中处理 NULL 值的方法
在日常使用数据库时,你在意过NULL值么? 其实,NULL值在数据库中是一个很特殊且有趣的存在,下面我们一起来看看吧: 在查询数据库时,如果你想知道一个列(例如:用户注册年限 USER_AGE)是否为 NULL,SQL 查询语句该怎么写呢? 是这样: SELECT * FROM TABLE WHERE USER_AGE = NULL 还是这样? SELECT * FROM TABLE WHERE USER_AGE IS NULL 当然,正确的写法应该是第二种(WHERE USER_AGE IS
-
列出SQL Server中具有默认值的所有字段的语句
专家解答 通过查询任何数据库中的三个系统表,你可以获得每个表的每一个字段的默认值.下面是这个核心查询.它返回分配给当前数据库中每个用户表的默认值.这个查询在SQL 2000和SQL 2005中都是兼容的. Quote: 复制代码 代码如下: SELECT SO.NAME AS "Table Name", SC.NAME AS "Column Name", SM.TEXT AS "Default Value" FROM dbo.sysobject
-
Oracle数据库中对null值的排序及mull与空字符串的区别
order by排序之null值处理方法 在对业务数据排序时候,发现有些字段的记录是null值,这时排序便出现了有违我们使用习惯的数据大小顺序问题.在Oracle中规定,在Order by排序时缺省认为null是最大值,所以如果是ASC升序则被排在最后,而DESC降序则排在最前.所以,为何分析数据的直观性方便性,我们需要对null的记录值进行相应处理. 这是四种oracle排序中NULL值处理的方法: 1.使用nvl函数 语法:Nvl(expr1, expr2) 若EXPR1是NULL,
-
MySQL中对于NULL值的理解和使用教程
NULL值的概念是造成SQL的新手的混淆的普遍原因,他们经常认为NULL是和一个空字符串''的一样的东西.不是这样的!例如,下列语句是完全不同的: mysql> INSERT INTO my_table (phone) VALUES (NULL); mysql> INSERT INTO my_table (phone) VALUES (""); 两个语句把值插入到phone列,但是第一个插入一个NULL值而第二个插入一个空字符串.第一个的含义可以认为是"电话号码不
-
SQL语句中不同的连接JOIN及join的用法
为了从两个表中获取数据,我们有时会用JOIN将两个表连接起来.通常有以下几种连接方式: JOIN or INNER JOIN(内连接) : 这两个是相同的,要求两边表同时有对应的数据,返回行,任何一边缺失数据就不显示. LEFT JOIN(左外连接):即使右边的表中没有匹配,也从左表返回所有的行. RIGHT JOIN(右外连接):即使左边的表中没有匹配,也从右表返回所有的行. FULL JOIN(全外连接):只要其中一个表中存在匹配就返回行. 如例,有grade表(课程号sn,分数scro
-
MySQL中关于null值的一个小问题
今天在测试null值的时候,发现了一个小问题,记录在这里,不知道大家以前遇到过没. 事情发展是这样的,在过滤一个表中的数值的时候,需要把age=2的列给剔除掉,然后查看剩余的列信息,这个操作看起来比较简单,我用一个表模拟一下过程: CREATE TABLE `test` ( `id` int(11) NOT NULL AUTO_INCREMENT, `age` int(11) DEFAULT NULL, `score` varchar(20) NOT NULL DEFAULT '',
-
SQL语句中的DDL类型的数据库定义语言操作
目录 SQL语句之DDL类型的数据库定义语言 1.DDL类型的SQL语句基本概述 2.DDL类型的SQL语句之数据库层面的操作 2.1.创建一个数据库 2.2.查看MySQL中有哪些数据库 2.3.进入某个数据库 2.4.查看当前处于哪个数据库中 3.DDL类型的SQL语句之数据库表层面的操作 3.1.创建一张数据表 3.2.查看当前数据库中所有的数据表 3.3.查询某张表的表结构 3.4.查询某张表的建表语句 3.5.在现有表中添加新的字段 3.6.修改现有表中的字段数据类型和字段名称 3.7
-
SQL语句中的ON DUPLICATE KEY UPDATE使用
目录 一:主键索引,唯一索引和普通索引的关系 主键索引 唯一索引: 普通索引: 二:ON DUPLICATE KEY UPDATE使用测试(MYSQL下的Innodb引擎) 1:ON DUPLICATE KEY UPDATE功能介绍: 2:ON DUPLICATE KEY UPDATE测试样例+总结: 总结: 一:主键索引,唯一索引和普通索引的关系 主键索引 主键索引是唯一索引的特殊类型. 数据库表通常有一列或列组合,其值用来唯一标识表中的每一行.该列称为表的主键. 在数据库关系图中为表定义一个
-
sql语句 update字段null不能用is null问题
目录 sql语句 update字段null不能用is null update更新数据时null字段是否更新进数据库总结 情况一:不需要更新进数据库 情况二:需要更新进数据库 (推荐方法3) sql语句 update字段null不能用is null update字段为 null 值时, 要用 set column = null, 而不是 set column is null UPDATE tableA set 字段a is null WHERE字段b = 条件; 例: mysql> UPDATE
随机推荐
- Python os模块介绍
- JS模态窗口返回值兼容问题的完美解决方法
- laypage前端分页插件实现ajax异步分页
- Angular.js中下拉框实现渲染html的方法
- 改进版通过Json对象实现深复制的方法
- php使用ereg验证文件上传的方法
- IIS7/iis7.5 HTTP Error 500.19 配置错误由于权限不足而无法读取配置文件的解决办法
- win2000/winXP 停止打印的bat
- asp.net SqlParameter关于Like的传参数无效问题
- DAM 简单跨数据库ADO.NET组件
- 以文本方式上传二进制文件的PHP程序
- 使用C语言提取子字符串及判断对称子字符串最大长度
- 全面理解闭包机制
- PHP连接MySql闪断自动重连的方法
- 决策树的python实现方法
- 使用mysql_udf与curl库完成http_post通信模块示例
- jquery struts 验证唯一标识(公用方法)
- jQuery实现可拖动的浮动层完整代码
- 加入收藏夹代码(兼容 gecko)
- 通过文字传递创建的图形按钮
其他
- python中的切片冒号的用法
- js import 同步加载
- python for循环求和
- router addRoutes 页面不显示
- IDEA阿里代码规约插件如何设置
- vscode axios 代码生成插件
- vue 响应式 视图怎么影响model
- 不同高度item recycleview 计算滑动距离
- BufferedReader读取JSON数据后格式异常
- MySQL 8配置对应驱动包
- Vue3列表循环滚动
- python pycharm 安装pdf2docx 失败
- python 分形 函数
- django-import-export如何放在页面
- js 获取 dom margin
- vue .第一个接口是否调用成功都执行下一段代码
- java CAP原理,分布式事务
- idea使用git拉代码每天都要输入一次密码
- pandas存储表格到同一个excel中
- schedule 配置详解