【发布时间】:2016-04-06 03:05:21
【问题描述】:
我正在尝试执行以下涉及复杂查询的操作; 1.首先我尝试根据一些逻辑选择列 2.然后根据所选列的值选择一个值 3. finally 基于之前的值,应用一个逻辑得到最终值
如何在 3rd Case..Then 语句的 ELSE 中获得 2 的结果?
CASE
CASE
CASE
WHEN MDC.Network ='I' THEN INNBenefitID ELSE OONBenefitID
END
WHEN 'INNDWO' THEN CASE WHEN DWO.Description IS NOT NULL THEN DWO.Description ELSE MDC.CostShareValue END
WHEN 'OONDWO' THEN CASE WHEN DWO.Description IS NOT NULL THEN DWO.Description ELSE MDC.CostShareValue END
ELSE isnull(dbo.fn_FormatText(MDC.CostShareValue, CostShareType),'''')
END
WHEN '0%' THEN 'Covered 100%'
WHEN '$0' THEN 'Covered 100%'
ELSE ????
END
【问题讨论】:
-
案例表达式,而不是案例陈述......
-
请解释您想要的逻辑并提供示例。
-
可能,
CROSS APPLY是你的朋友... -
这是在 Select 语句中,我必须根据列值有条件地选择一列以设置一些逻辑,然后对返回的值进行一些字符串转换。只是我想在外部 Case 表达式的 Else 中返回内部 Case..when 的值。
标签: sql sql-server