首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SSIS表达式

SSIS表达式
EN

Stack Overflow用户
提问于 2013-12-16 16:15:01
回答 2查看 341关注 0票数 2

我有以下SQL代码

代码语言:javascript
复制
update ETL.TempRH 
set resourcer = IF(
               qualification IN (47,49,50,164,187,252,185,239,251),
                   "resourcer"  , type_Staff);

我需要把它转换成ssis表达式。我试过了但没成功。

代码语言:javascript
复制
(qualification = 47  || 
 qualification = 49  ||  
 qualification = 50  || 
 qualification = 164 || 
 qualification = 187 || 
 qualification = 252 || 
 qualification = 185 || 
 qualification = 239 || 
 qualification = 251 ? "resourcer" : type_Staff)
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-12-16 16:18:18

您遇到的一个问题是SSIS中的相等比较运算符是==而不是=

更广泛地说,这些资历数字会不会发生变化?它们甚至是模模糊糊的动态吗?

您可能只想使用一个查找组件来存储您的资源限定值,根据它查找限定值,如果匹配,则将您的type_Staff列替换为" resourcer“。

因此,例如,在查找中,将查询设置为

代码语言:javascript
复制
SELECT 47 as Qualification, 1 as IsResourcer
union
SELECT 49, 1
etc
etc

加入资格,然后在派生列中只需

代码语言:javascript
复制
(IsResourcer == 1 ? "Resourcer" : Type_Staff)

如果您不关心保留原始type_Staff值,则可以将查找查询更改为

代码语言:javascript
复制
   SELECT 47 as Qualification, 'Resourcer' as type_Staff
    union
    SELECT 49, 'Resourcer'
    etc
    etc

并将type_Staff设置为替换现有的type_Staff列。

票数 5
EN

Stack Overflow用户

发布于 2015-04-30 14:01:20

只需在SSIS表达式中使用以下嵌套查询逻辑:

代码语言:javascript
复制
Field == "TrueCondition1" ? “True” : ( Field == "TrueCondition2" ? “True” : ( Field == "TrueCondition3 " ? “True” : ( Field == "TrueCondition4" ? “True” : “False"  ) ) )

因此,根据查询字段==限定&您正在检查的限定值将成为"TrueCondition“。

代码语言:javascript
复制
@[User::qualification]  == 47 ? @[User::resourcer]  : (@[User::qualification] == 49 ? @[User::resourcer] : (@[User::qualification] == 40 ? @[User::resourcer] : @[User::type_staff] ))

尝尝这个。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20615489

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档