2017-03-17 36 views
0

我有一個包含四列('YES,NO,N/A})值的表格。我想要得到的是一個帶有連續名稱的列,它們用雙下劃線表示'YES'值。在SQL Server中使用IF條件的CONCAT

\, A, B, C, D 
1, YES, NO, YES, N/A 
2, NO, YES, N/A, N/A 
3, YES, NO, NO, YES 

預期結果:

A__C 
B 
A__D 

喜歡的東西:

select CONCAT(
IF(A = 'YES', 'A'), 
IF(B = 'YES', 'B'), 
IF(C = 'YES', 'C'), 
IF(D = 'YES', 'D')) 
from my_table 
+0

使用['CASE'](https://msdn.microsoft.com/en-us/library/ms181765.aspx)。 – Siyual

回答

3

希望我明白你說得對,你想要一個雙下劃線分隔符。 此解決方案無需任何子查詢或cte處理。

select substring(
      iif(a='YES','__A','') + iif(b='YES','__B','') + 
      iif(c='YES','__C','') + iif(d='YES','__D','') 
     ,3,100) 
from table1 

應該知道這個:substring('', 3, 100)將使用SqlServer。

+0

這工作得很好,似乎是更緊湊的解決方案。謝謝! – Nic

0
Select case A then 'YES' then 'A' else '_'end + case B then 'YES' then 'B' else '_'end +case C then 'YES' then 'C' else '_'end +case D then 'YES' then 'D' else '_'end as result from my_table 
0
WITH ABC 
as 
( 
Select 
    (
    CASE WHEN A = 'YES' THEN 'A_' ELSE '' END as A + 
    CASE WHEN B = 'YES' THEN 'B_' ELSE '' END as B + 
    CASE WHEN C = 'YES' THEN 'C_' ELSE '' END as C + 
    CASE WHEN D = 'YES' THEN 'D_' ELSE '' END as D 
    ) as output 
) 
Select case when len(output) = 2 then left (output,1) 
     else output 
     end as output 
From ABC 
2

假設T1是你的表:

SELECT CASE WHEN LEN(X)>0 THEN LEFT(X, LEN(X)-2) ELSE '' END AS Y 
FROM (
    SELECT 
    CASE WHEN A='YES' THEN 'A__' ELSE '' END + CASE WHEN B='YES' THEN 'B__' ELSE '' END + CASE WHEN C='YES' THEN 'C__' ELSE '' END + CASE WHEN D='YES' THEN 'D__' ELSE '' END AS X 
    FROM T1 
    ) A