我正在尝试在我的存储进程中创建一个计算字段。我有一个projectID列和3个列,其中包含'yes‘或'no’值,它们对应于受影响的区域。我必须收集所有'yes‘值,并将相应区域的名称插入到一个名为RegionImpacted的新字段中。可能有多个区域受到影响。
发布于 2011-03-09 00:20:43
其他人建议的嵌套case语句可以工作,但如果您需要添加额外的区域,它们很快就会变得非常复杂,因为它们的复杂性呈指数级增加。例如,在实现嵌套的case语句解决方案之前,考虑它们在6个区域中的样子。我更喜欢使用连接的case语句方法。
DECLARE @Region1 CHAR(3)
, @Region2 CHAR(3)
, @Region3 CHAR(3)
, @Result VARCHAR(128)
SET @Region1 = ' NO'
SET @Region2 = ' NO'
SET @Region3 = ' NO'
SELECT  Regions = CASE WHEN ( @Region1 = ' NO'
                                        AND @Region2 = ' NO'
                                        AND @Region3 = ' NO'
                                     ) THEN 'None'
                        ELSE CASE @Region1
                                WHEN 'YES' THEN 'Region1 '
                                ELSE ''
                            END 
                            + CASE @Region2
                                WHEN 'YES' THEN 'Region2 '
                                ELSE ''
                            END 
                            + CASE @Region3
                                WHEN 'YES' THEN 'Region3 '
                                ELSE ''
                            END
                        END         https://stackoverflow.com/questions/5234768
复制相似问题