如何在单个 SQL CASE 语句中获取多个列?

新手上路,请多包涵

我正在尝试从单个 CASE 语句中获取多个列(在这种情况下为保险代码,保险名称)。

已尝试以下查询,但它将被保险人代码和被保险人名称连接为一列。

从这样的 CASE 语句中准确返回两列的正确语法是什么?

 select
    case
        when a.policyno[2] in ('E', 'W') then c.insuredcode || c.insuredname
        else b.insuredcode || b.insuredname
    end
from prpcmain a
left join prpcinsured_1 b on b.proposalno=a.proposalno
left join prpcinsured_2 c on c.proposalno=a.proposalno
where a.policyno in (select policyno from policyno_t);

原文由 Michael.Y 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 463
2 个回答

CASE 语句只能返回单列而不是多列

您需要两个不同的 CASE 语句来执行此操作

select
    case
        when a.policyno[2] in ('E', 'W') then c.insuredcode
        else b.insuredcode
    end as insuredcode ,
    case
        when a.policyno[2] in ('E', 'W') then  c.insuredname
        else b.insuredname
    end as insuredname
from prpcmain a
left join prpcinsured_1 b on b.proposalno=a.proposalno
left join prpcinsured_2 c on c.proposalno=a.proposalno
where a.policyno in (select policyno from policyno_t);

原文由 Pரதீப் 发布,翻译遵循 CC BY-SA 3.0 许可协议

就像任何语言中的 if/else 条件一样,您可以在 When 语句中定义您的条件,如果为 true,则 SQL 执行 Then 语句,否则执行 Else 部分,如下所述:

      Select
                 CASE
                    WHEN (cs.ResultSubmitToHOD = 1) THEN 'HOD'
                    WHEN (cs.ResultSubmitToExamDep = 1) THEN 'Exam'
                    ELSE 'Teacher'
                END AS ResultSubmitStatus
     From dbo.CourseSection as cs

原文由 Luqman Cheema 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进