NULLIF与ISNULL的交叉使用

事件源于字词字段拼接,由于不清楚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赋值的同时付给了结果内存。

转载于:https://www.cnblogs.com/xianeri/p/8960744.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值