1

SSIS が*の一部だと思うのは私だけですか?

質問があります:

SELECT * FROM Table1

そして、これを宛先ファイルに特定の長さのテキストファイルに入れたいです(クライアントからの仕様があります)。

たとえば、フィールド 1 のサイズ: 20、フィールド 2 のサイズ: 3 などです。

フィールド ポジションもあり、フィールド 1: 1-20、フィールド 2: 21-23 などです。

ソースを SQL クエリとして、フラット ファイルを宛先として持つ SSIS パッケージを作成しました。私は一生これを機能させることはできません。

テキスト ファイルのデータはすべてめちゃくちゃです (あちこちに散らばっており、列はありません)。

これは世界で最も簡単な作業ですが、私にはできません。それが私なのか、それとも SSIS がただのゴミなのかはわかりません。

4

2 に答える 2

1

私は実際にこれを先週やったばかりです。これを行う関数を作成し、関数を呼び出すフィールドごとに作成しました。

ここに関数があります

/*
USE [Newton-Dev]
GO
/****** Object:  UserDefinedFunction [dbo].[CharPad]    Script Date: 1/10/2015 11:38:27 AM ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
/*
Script  : Character Padding Function; Assist with fixed width file creation
Version : 1.0 (01/08/2015)
Author  : Jeffery Williams

*/
ALTER FUNCTION [dbo].[CharPad] (
     @Input VARCHAR(255)
    ,@OutputWidth INT
    ,@OutputAlign VARCHAR(5)
    ,@PadCharacter CHAR(1) )
RETURNS VARCHAR(255)
AS
BEGIN
DECLARE @Output VARCHAR(255)
DECLARE @InputWidth INT

SET @InputWidth = LEN(@Input)

IF @InputWidth > @OutputWidth
    BEGIN 
        IF @OutputAlign = 'LEFT'
            BEGIN
            SET @Output = LEFT(@Input,@OutputWidth)
            END
        IF @OutputAlign = 'RIGHT'
            BEGIN
            SET @Output = RIGHT(@Input,@OutputWidth)
            END
    END

IF @InputWidth < @OutputWidth 
    BEGIN 
        IF @OutputAlign = 'RIGHT'
            BEGIN
            SET @Output = REPLICATE(@PadCharacter, @OutputWidth - @InputWidth ) + @Input
            END
        IF @OutputAlign = 'LEFT'
            BEGIN
            SET @Output =@Input+ REPLICATE(@PadCharacter, @OutputWidth - @InputWidth )
            END
    END

IF @InputWidth = @OutputWidth 
    SET @Output = @Input

RETURN (@Output)
END

関数を呼び出して固定幅の出力を提供するクエリを次に示します。

SELECT --dbo.CharPad (DeltaLineId,8,'LEFT',' '), dbo.CharPad (DeltaElgId,8,'LEFT',' ')
       dbo.CharPad (CARRIER_ID,6,'LEFT',' ')
       ,dbo.CharPad (GROUP_NUM,7,'RIGHT','0')
      ,dbo.CharPad (LEFT('0000' + SUB_GROUP_ID, 4),9,'LEFT',' ')
      ,dbo.CharPad (SVC_TYPE,1,'LEFT',' ')
      ,dbo.CharPad (FILLER_1,1,'LEFT',' ')
      ,dbo.CharPad (FILLER_2,5,'LEFT',' ') 
      ,dbo.CharPad (RATE_CODE,2,'LEFT',' ')
      ,dbo.CharPad (FILLER_3,1,'LEFT',' ')
      ,dbo.CharPad (ELIG_CODE,1,'LEFT',' ')
      ,dbo.CharPad (EFF_DATE,8,'LEFT',' ') 
      ,dbo.CharPad (TERM_DATE,8,'LEFT',' ') 
      ,dbo.CharPad (SUBSC_SSN,9,'LEFT',' ')  
      ,dbo.CharPad (INDIV_SSN,9,'LEFT',' ') 
      ,dbo.CharPad (CHNG_SSN,9,'LEFT',' ')   
      ,dbo.CharPad (REL_CODE,2,'LEFT',' ') 
      ,dbo.CharPad (HIRE_DATE,8,'LEFT',' ')  
      ,dbo.CharPad (DOB,8,'LEFT',' ') 
      ,dbo.CharPad (REL_TYPE,1,'LEFT',' ')  
      ,dbo.CharPad (FIRST_NAME,24,'LEFT',' ') 
      ,dbo.CharPad (MID_NAME,24,'LEFT',' ')                 
      ,dbo.CharPad (LAST_NAME,24,'LEFT',' ') 
      ,dbo.CharPad (GENDER,1,'LEFT',' ')  
      ,dbo.CharPad (POP_DESC,5,'LEFT',' ') 
      ,dbo.CharPad (ADR_LINE_1,30,'LEFT',' ')                      
      ,dbo.CharPad (ADR_LINE_2,30,'LEFT',' ') 
      ,dbo.CharPad (CITY,30,'LEFT',' ')                           
      ,dbo.CharPad ([STATE],2,'LEFT',' ') 
      ,dbo.CharPad (COUNTY_CODE,3,'LEFT',' ')  
      ,dbo.CharPad (COUNTRY_CODE,3,'LEFT',' ') 
      ,dbo.CharPad (ZIP,5,'LEFT',' ')    
      ,dbo.CharPad (ZIP_EXT,4,'LEFT',' ') 
      ,dbo.CharPad (FILLER_4,21,'LEFT',' ')               
      ,dbo.CharPad (USER_DEFINED,30,'LEFT',' ') 
      ,dbo.CharPad (WAIT_PERIOD,1,'LEFT',' ')  
      ,dbo.CharPad (CAID,9,'RIGHT','0') 
      ,dbo.CharPad (FILLER_5,9,'LEFT',' ') 
FROM export.DeltaLine

*/
于 2015-01-10T17:33:14.310 に答える
1

フラット ファイル用に定義した接続マネージャーに移動します。左のボックスで [一般] を選択し、[形式] を [固定幅] に設定します。次に、左側のボックスで [Advanced] を選択します。ここで、各フィールドの OutputColumnWidth を設定できます。最後に、左側のボックスで [プレビュー] を選択して、SSIS パッケージを実行する前に結果を確認します。

お役に立てれば。コッシュ

于 2013-03-11T20:12:18.407 に答える