SQL Server里的 ISNULL 与 NULLIF

时间:2023-03-08 20:38:08

SQL Server 中有两个參数,语法:

    ISNULL(check_expression, replacement_value)

check_expression 与 replacement_value 数据类型必须一致

    假设 check_expression 为 NULL,则返回 replacement_value

假设 check_expression 不为 NULL,则返回 check_expression

NULLIF 用于检查两个表达式,语法:

NULLIF(expression, expression)

假设两个 expression 相等,则返回 NULL,该 NULL 为第一个 expression 的数据类型

    假设两个 expression 不相等,则返回第一个 expression

Sql Server中两个推断是否为空的函数NULLIF和ISNULL的说明例如以下:

NULLIF:须要两个參数,假设两个指定的表达式等价,则返回null

样例:NULLIF(a,b)

说明:假设a和b是相等的,那么返回NULL,假设不相等返回a

select NULLIF('eqeqweqwe','1') 结果是eqeqweqwe

select NULLIF(1,1) 结果是NULL

a和b的类型要一致

ISNULL:须要两个參数,目标是讲null替换为指定的值,若第一个參数不为null,则返回第一个參数

样例:ISNULL(a,b)

说明:假设a和b同一时候为NULL,返回NULL,假设a为NULL,b不为NULL,返回b,假设a不为NULL,b为NULL返回a,假设a和b都不为NULL返回a

select ISNULL(null,null)结果是null

select ISNULL(null,33)结果是33

select ISNULL('ddd',null)结果是ddd

select ISNULL(44,33)结果是44

isnumeric:确认表达式是否为有效的数字形式