我写了一个类似这样的T-SQL语句(最初的看起来不同,但我想在这里给出一个简单的例子):

SELECT first_name + 
    CASE last_name WHEN null THEN 'Max' ELSE 'Peter' END AS Name
FROM dbo.person

此语句没有任何语法错误,但case-clause总是选择else部分-如果last_name为空也是如此。但是为什么呢?

我想做的是联合first_name和last_name,但如果last_name为空,整个名称变成空:

SELECT first_name +
   CASE last_name WHEN null THEN '' ELSE ' ' + last_name END AS Name 
FROM dbo.person

你知道问题出在哪里吗?


当前回答

我找到了解决办法。只ISNULL CASE语句:

ISNULL(CASE x WHEN x THEN x ELSE x END, '') AS 'BLAH'

其他回答

try:

SELECT first_name + ISNULL(' '+last_name, '') AS Name FROM dbo.person

这将把空格加到姓氏上,如果它为空,整个空格+姓氏将变为null,您只得到一个名字,否则您将得到一个firts+空格+姓氏。

只要设置了空字符串连接的默认设置,这就可以工作:

SET CONCAT_NULL_YIELDS_NULL ON 

这应该不是一个问题,因为在未来的SQl Server版本中,OFF模式将会消失

我找到了解决办法。只ISNULL CASE语句:

ISNULL(CASE x WHEN x THEN x ELSE x END, '') AS 'BLAH'

当你在尝试时感到沮丧时:

CASE WHEN last_name IS NULL THEN '' ELSE ' '+last_name END

试试这个吧:

CASE LEN(ISNULL(last_Name,''))
WHEN 0 THEN '' 
ELSE ' ' + last_name
END AS newlastName

LEN(ISNULL(last_Name, "))测量该列中的字符数,无论该列是空的还是空的,都将为零,因此WHEN 0 THEN将计算为true并返回“如预期的那样”。

我希望这是一个有用的替代方案。

我已经包含了sql server 2008及以上版本的测试用例:

DECLARE @last_Name varchar(50) = NULL

SELECT 
CASE LEN(ISNULL(@last_Name,''))
WHEN 0 THEN '' 
ELSE 'A ' + @last_name
END AS newlastName

SET @last_Name = 'LastName'

SELECT 
CASE LEN(ISNULL(@last_Name,''))
WHEN 0 THEN '' 
ELSE 'A ' + @last_name
END AS newlastName
CASE  
    WHEN last_name IS null THEN '' 
    ELSE ' ' + last_name 
END

Jason发现了一个错误,所以这可以工作…

有人能确认其他平台的版本吗? SQL服务器:

SELECT
CASE LEN(ISNULL(last_name,'')) 
WHEN 0 THEN '' 
ELSE ' ' + last_name
END AS newlastName

MySQL:

SELECT
CASE LENGTH(IFNULL(last_name,'')) 
WHEN 0 THEN '' 
ELSE ' ' + last_name
END AS newlastName

Oracle:

SELECT
CASE LENGTH(NVL(last_name,'')) 
WHEN 0 THEN '' 
ELSE ' ' + last_name
END AS newlastName