Best way to do nested case statement logic in SQL Server(在 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 语句逻辑的最佳方法的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在 SQL Server 中执行嵌套 case 语句逻辑的最佳方法
基础教程推荐
- 在 SQL 中连接多个表 2021-01-01
- SQL 效率:WHERE IN 子查询 vs. JOIN 然后 GROUP 2021-01-01
- 将 SQL Server DateTime 列迁移到 DateTimeOffset 2021-01-01
- SSMS 中的权限问题:“对象 'extended_properties'、数据库 'mssqlsystem_resource'、... 错误 229)上的 SELECT 权限被拒绝" 2022-01-01
- SQL:使用来自具有相同列名的两个表中的数据... 2021-01-01
- 需要 MySQL 5.1 中的抽象触发器来更新审计日志 2021-01-01
- 是否可以执行按位分组功能? 2021-01-01
- 无法解决整理冲突 2021-01-01
- SQL Server 实例在登录协商期间返回无效或不受支持的协议版本 2021-01-01
- 如何使用 mysql.connector 禁用查询缓存 2022-01-01
