2

我有这个 SQL 代码:

Select [Name] = case when CHARINDEX(''.'', [Name])>0 
                            then LEFT([Name],CHARINDEX(''.'', [Name])-1)
                        else [Name] end,
        [System] = case when reverse(SUBSTRING(REVERSE( System),1,CHARINDEX('':'', REVERSE(System)))) like '':'' 
                            then (  System + ''\'')
                        else    System end

我正在创建我的 SSIS 工作流,以便使用 SSIS 构建我的 ETL。为了创建上面的转换,我使用了派生列对象。对于第一个语句,我尝试这样做:

ISNULL(SUBSTRING([Name],1,FINDSTRING([Name],".",1) - 1)) ? [Name] : SUBSTRING([Name],1,FINDSTRING([Name],".",1) - 1)

但它给了我错误......

我怎样才能进行这两个转换?

谢谢!

4

2 回答 2

1
  1. 创建两个变量,如 Name (String) 和 t (Int32)。
  2. 使用两个表达式任务

在此处输入图像描述

  1. EXPR_Set_Flag_For_Dot:@[User::t] = (FINDSTRING(@[User::Name], ".", 1) == 0 ? 0 : 1 )
  2. EXPR_Get_SubString: FINDSTRING( @[User::Name] ,".",1) == 0 ? @[User::Name] : SUBSTRING( @[User::Name] ,1,FINDSTRING( @[User::Name] ,".",1) - @[User::t] )

注意:在您的表达式中,您在 SubString 中使用 -1,当名称中没有点 (.) 时,表达式将引发错误。FindString 将给出 0,因此不允许在外部 SubString 中使用 0-1。第一个表达式已经对此进行了检查,并在没有点时将 @[User::t] 分配为 0,因此 0-0 不会出错。

于 2017-05-04T13:57:11.687 回答
0

您可以使用Expression Task来实现这一点

  • 对于[Name]表达,您可以使用以下内容

    @[User::Name] = FINDSTRING( @[User::Name] ,".",1) == 0 ?  @[User::Name] : LEFT(SUBSTRING( @[User::Name] ,1,FINDSTRING( @[User::Name] ,".",1) ), LEN(SUBSTRING(@[User::Name] ,1,FINDSTRING( @[User::Name] ,".",1))) -1)
    

SUBSTRING不允许从可以LEFT用来实现此目的的长度中减去 -1

  • 对于[System]表达,您可以使用以下内容

    @[User::System] = REVERSE(SUBSTRING(REVERSE(@[User::System]),1,FINDSTRING( REVERSE(@[User::System]),":",1))) == ":"  ? @[User::System] + "\\"    : @[User::System]
    
于 2017-05-07T06:59:24.690 回答