码迷,mamicode.com
首页 > 其他好文 > 详细

NULLIF与ISNULL的交叉使用

时间:2018-04-27 12:12:27      阅读:176      评论:0      收藏:0      [点我收藏+]

标签:select   解释   isnull   使用   空值   UI   功能   函数   返回   

事件源于字词字段拼接,由于不清楚NULLIF的本质导致惨剧发生。

1 1 Select IsNull(NullIf(‘‘, dbo.f_CTRL_GetAlloy(6063, T5)), 6063-T5)
2 2 Select IsNull(NullIf(dbo.f_CTRL_GetAlloy(6063, T5), ‘‘), 6063-T5)
3 
4 函数f_CTRL_GetAlloy功能解释:当6063-T5传入时,返回空;其他值传入时,返回两字段相加字段。

以上SQL都有NULLIF/ISNULL依次处理,函数f_CTRL_GetAlloy传回值都为空值,所以NULLIF此时返回的都为NULL。

1 Select NullIf(‘‘, dbo.f_CTRL_GetAlloy(6063, T5)) As NULLIF1
2 Select NullIf(dbo.f_CTRL_GetAlloy(6063, T5), ‘‘) As NULLIF2 得到两个NULL值

此时剩下的SQL

1 Select IsNull(Null, 6063-T5)

照常理应该得到值

1 6063-T5

但是实际得到两个值,SQL1/SQL2

1 1 Select NullIf(‘‘, dbo.f_CTRL_GetAlloy(6063, T5)) As NULLIF1 = 6
2 2 Select NullIf(dbo.f_CTRL_GetAlloy(6063, T5), ‘‘) As NULLIF2 = 6063-T5

初步认为NUIFF赋值的同时付给了结果内存。

NULLIF与ISNULL的交叉使用

标签:select   解释   isnull   使用   空值   UI   功能   函数   返回   

原文地址:https://www.cnblogs.com/xianeri/p/8960744.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!