在 SQL Server 中执行嵌套 case 语句逻辑的最佳方法

Best way to do nested case statement logic in SQL Server(在 SQL Server 中执行嵌套 case 语句逻辑的最佳方法)
本文介绍了在 SQL Server 中执行嵌套 case 语句逻辑的最佳方法的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在编写一个 SQL 查询,其中返回的一些列需要根据相当多的条件进行计算.

我目前正在使用嵌套的 case 语句,但它变得很混乱.有没有更好(更有条理和/或可读性更强)的方法?

(我使用的是 Microsoft SQL Server,2005)

<小时>

一个简化的例子:

SELECT列1,col2,col3,案件WHEN 条件然后案件当条件 1然后案件当条件 2然后计算1ELSE计算2结尾别的案件当条件 2然后计算3ELSE计算4结尾结尾别的案件当条件 1然后案件当条件 2然后计算5ELSE计算6结尾别的案件当条件 2然后计算7ELSE计算8结尾结尾END AS 'calculatedcol1',第 4 行,col5 -- 等等发件人表

解决方案

你可以尝试一些 COALESCE 技巧,例如:

<前>选择合并(CASE WHEN 条件 1 THEN 计算 1 ELSE NULL END,CASE WHEN 条件 2 THEN 计算 2 ELSE NULL END,等等...)

I'm writing an SQL Query, where a few of the columns returned need to be calculated depending on quite a lot of conditions.

I'm currently using nested case statements, but its getting messy. Is there a better (more organised and/or readable) way?

(I am using Microsoft SQL Server, 2005)


A simplified example:

SELECT
    col1,
    col2,
    col3,
    CASE
        WHEN condition 
        THEN
            CASE
                WHEN condition1 
                THEN
                    CASE 
                        WHEN condition2
                        THEN calculation1
                        ELSE calculation2
                    END
                ELSE
                    CASE 
                        WHEN condition2
                        THEN calculation3
                        ELSE calculation4
                    END
            END
        ELSE 
            CASE 
                WHEN condition1 
                THEN 
                    CASE
                        WHEN condition2 
                        THEN calculation5
                        ELSE calculation6
                    END
                ELSE
                    CASE
                        WHEN condition2 
                        THEN calculation7
                        ELSE calculation8
                    END
            END            
    END AS 'calculatedcol1',
    col4,
    col5 -- etc
FROM table

解决方案

You could try some sort of COALESCE trick, eg:

SELECT COALESCE(
  CASE WHEN condition1 THEN calculation1 ELSE NULL END,
  CASE WHEN condition2 THEN calculation2 ELSE NULL END,
  etc...
)

这篇关于在 SQL Server 中执行嵌套 case 语句逻辑的最佳方法的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Execute complex raw SQL query in EF6(在EF6中执行复杂的原始SQL查询)
Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)