How to use CASE to get 3 columns from a single column?

佐手、 提交于 2019-12-11 23:27:24

问题


I have one table "DataDollar"...and 2 columns "LineNmbr" & "DollarAmt" in that.

I need to display this column values as in three columns depending upon their values.

Please help me !

SELECT
 DollarAmt AS
 CASE LineNmbr
    WHEN 19
        THEN  'A-Amt'
    WHEN 20
        THEN   'P-Amt'
    ELSE
          'D-Amt'
  END        
 FROM DataDollar

回答1:


Try using three case expressions, one for each column in the result set:

SELECT
    CASE LineNumber WHEN 19 THEN DollarAmt END AS AAmt,
    CASE LineNumber WHEN 20 THEN DollarAmt END AS PAmt,
    CASE WHEN LineNumber <> 19 AND LineNumber <> 20
        THEN DAmt
    END AS DAmt
FROM DataDollar



回答2:


select 
  case LineNmbr when 19 then DollarAmt else null end as 'A-Amt',  
  case LineNmbr when 20 then DollarAmt else null end as 'P-Amt',
  case when (LineNmbr <> 19) and (LineNmbr <> 20) then DollarAmt else null end as 'D-Amt'
from DataDollar    


来源:https://stackoverflow.com/questions/5159869/how-to-use-case-to-get-3-columns-from-a-single-column

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!