zoukankan      html  css  js  c++  java
  • [SQLTips]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赋值的同时付给了结果内存。

  • 相关阅读:
    unity c# 获取系统时间
    如果你想让继承MonoBehaviour的类变成Singleten
    关于程序员
    开始养成记录的习惯吧
    关于结构体的赋值问题
    数学中的集合,群,环,域
    励志
    [编程题] 进制均值
    javaEE 入门
    jsp内置对象2
  • 原文地址:https://www.cnblogs.com/xianeri/p/8960744.html
Copyright © 2011-2022 走看看