### SQL中的ISNULL函数介绍
* * * * *
ISNULL
使用指定的替换值替换 NULL。
#### 语法
ISNULL ( check_expression , replacement_value )
#### 参数
check_expression 将被检查是否为 NULL的表达式。check_expression 可以是任何类型的。
replacement_value 在 check_expression 为 NULL时将返回的表达式。replacement_value 必须与 check_expresssion 具有相同的类型。
返回类型: 返回与 check_expression 相同的类型。
#### 注释
如果 check_expression 不为 NULL,那么返回该表达式的值;否则返回 replacement_value。
ascore 表内容如下:
![](https://box.kancloud.cn/d837f66c21a60d8c2fa9fb27b88b3a3f_506x173.png)
查询出其中成绩(score)小于等于60的学生信息保存至表变量@tempTable中,当学生成绩为空时,成绩记为0。
~~~
declare @tempTable table(
stuname nchar(10),
stuage int,
stuscore float);
insert into @tempTable
select name,age,ISNULL(score,0) from ascore
where ISNULL(score,0)<=60
select * from @tempTable
~~~
运行结果:
![](https://box.kancloud.cn/b6211f5532ff0a1f3cdf57ef81ae2e41_253x94.png)
#### ISNULL 与 AVG 一起使用
下面的示例查找学生的平均成绩,用值 70.00 替换 titles 表的 score 列中的所有 NULL 条目。
~~~
SELECT AVG(ISNULL(score, 70.00))
FROM ascore
~~~
* * * * *
MySQL语句参考:
http://www.w3school.com.cn/sql/sql_isnull.asp
- 目录
- 数据库表
- 13.7.5.6 SHOW COLUMNS Syntax
- Mysql生成列
- 表注释
- 默认字符集
- 索引
- 外键约束
- 数据类型
- NULL
- 查询语句
- IF
- CASE
- FIND_IN_SET
- 更新语句
- 复制更新
- 截取更新
- 插入语句
- 从一张表查询一个字段值插入另一个表中
- 统计函数
- COUNT
- 分组统计
- 日期时间字段按照日期分组
- GROUP_CONCAT
- 多字段关联
- LENGTH
- mb_strlen()
- SUM
- 按周,按月,按日分组统计数据
- 日期时间
- MySQL日期时间数据类型使用总结
- 计算日期差
- 插入当前日期时间
- 时间比较
- datetime
- 日期时间取时间段
- 统计
- 整型unix时间戳
- 计算两条相邻记录的时间差
- 日期时间-函数
- 常用函数
- CURDATE
- DATEDIFF
- DATE_ADD
- DATE_SUB
- EXTRACT
- NOW
- TO_DAYS
- UNIX_TIMESTAMP
- 作为时间比较
- FROM_UNIXTIME
- DATE_FORMAT
- TIMESTAMPDIFF
- 触发器
- 存储过程
- MySQL存储过程的基本函数
- 分页存储过程
- 存储过程教程
- 临时表
- 备份表
- CRM
- 客户关系表
- 通讯录
- SQL函数
- ISNULL
- IFNULL
- SUBSTR
- 模糊查询
- JSON
- Json函数
- Json数据类型
- 使用Json
- 使用navicat
- 虚拟列
- CRUD
- 索引设计
- 增加多字段索引
- 共享排他锁