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。spa

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

此时剩下的SQLcode

1 Select IsNull(Null, '6063-T5')

照常理应该获得值blog

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赋值的同时付给告终果内存。内存

相关文章
相关标签/搜索