Derived Column to handled mulitple conditions in CASE statement?(在CASE语句中处理多个条件的派生列?)
本文介绍了在CASE语句中处理多个条件的派生列?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一个CASE
语句可以用,但因为我必须在SSIS中执行,所以我感到困惑:
SELECT [BPCNUM_0], TYPE,
CASE
WHEN [TYPE]=1 THEN 'Normal'
WHEN [TYPE]=2 THEN 'Divers'
WHEN [TYPE]=3 THEN 'Intra-Société'
WHEN [TYPE]=4 THEN 'Prospect'
END AS TYPE
FROM table
如您所见,Case语句计算一列中的值,并根据它们是什么重命名它们。 当我在SSIS上尝试此功能时,它不起作用
[TYPE] == 1 ? "Normal" : [TYPE] == 2 ? "Divers" : [TYPE] == 3 ? "Intra-Société" : [TYPE] == 4 ? "Prospect"
我也试过
[TYPE] == "1" ? "Normal" : [TYPE] == "2" ? "Divers" : [TYPE] == "3" ? "Intra-Société" : [TYPE] == "4" ? "Prospect"
但它也没有起作用。
推荐答案
您的表达式需要添加最后一个Else语句,因为它应该知道在验证上述条件时要赋值的值:
[TYPE] == 1 ? "Normal" :
[TYPE] == 2 ? "Divers" :
[TYPE] == 3 ? "Intra-Société" :
[TYPE] == 4 ? "Prospect" : ""
相当于SQL中的以下内容:
SELECT [BPCNUM_0], TYPE,
CASE
WHEN [TYPE]=1 THEN 'Normal'
WHEN [TYPE]=2 THEN 'Divers'
WHEN [TYPE]=3 THEN 'Intra-Société'
WHEN [TYPE]=4 THEN 'Prospect'
ELSE ''
END AS TYPE
FROM table
如果您需要赋值NULL
而不是空字符串,可以使用以下表达式(假设派生的列类型为DT_WSTR
):
[TYPE] == 1 ? "Normal" :
[TYPE] == 2 ? "Divers" :
[TYPE] == 3 ? "Intra-Société" :
[TYPE] == 4 ? "Prospect" : NULL(DT_WSTR,50)
这篇关于在CASE语句中处理多个条件的派生列?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:在CASE语句中处理多个条件的派生列?
猜你喜欢
- 在 Oracle 中创建 CTE 2022-01-01
- SSMS 中的权限问题:“对象 'extended_properties'、数据库 'mssqlsystem_resource'、... 错误 229)上的 SELECT 权限被拒绝" 2022-01-01
- 如何将uuid存储为数字? 2021-01-01
- SQL Server 将 Varchar 转换为日期时间 2021-01-01
- MySql 错误 150 - 外键 2021-01-01
- HEROKU - 无法运行 git push heroku master 2021-01-01
- 如何在oracle中获取字符串最右边的10个位置 2021-01-01
- 创建索引时,具有 mysql 数据库迁移的实体框架失败 2022-01-01
- MySQL(Windows10)使用 MyISAM 表进行 FULLTEXT 搜索不起作用 2022-01-01
- Oracle SQL 转置 2022-01-01