スクリプト コンポーネントのコーディングおよびデバッグ

SSIS デザイナでは、スクリプト コンポーネントにメタデータ デザイン モードとコード デザイン モードの 2 つのモードがあります。[スクリプト変換エディタ] を開くと、スクリプト コンポーネントはメタデータ デザイン モードになります。このモードでは、メタデータを構成し、コンポーネントのプロパティを設定します。メタデータ デザイン モードで、スクリプト コンポーネントのプロパティを設定して、入力と出力を構成したら、コード デザイン モードに切り替えてカスタム スクリプトを記述できます。メタデータ デザイン モードとコード デザイン モードの詳細については、「スクリプト コンポーネント エディタでのスクリプト コンポーネントの構成」を参照してください。

コード デザイン モードでのスクリプトの記述

スクリプト コンポーネント開発環境

スクリプトを記述するには、[スクリプト変換エディタ][スクリプト] ページで [スクリプトの編集] をクリックし、MicrosoftVisual Studio Tools for Applications (VSTA) IDE を開きます。VSTA IDE には、色分け表示が可能な Visual Studio エディタ、IntelliSense、オブジェクト ブラウザなど、Visual Studio .NET 環境での標準機能がすべて含まれています。

スクリプト コードは、MicrosoftVisual Basic 2008 または MicrosoftVisual C# 2008 で記述されます。スクリプト言語を指定するには、[スクリプト変換エディタ][ScriptLanguage] プロパティを設定します。その他のプログラミング言語を使用する場合は、選択した言語でカスタム アセンブリを作成し、スクリプト コンポーネント内のコードからその機能を呼び出すことができます。

スクリプト コンポーネントで作成したスクリプトは、パッケージ定義に格納されます。スクリプト ファイルが別途存在するわけではありません。したがって、スクリプト コンポーネントを使用してもパッケージの配置には影響しません。

注意注意

パッケージをデザインする際、スクリプト コードは一時的にプロジェクト ファイルに書き込まれます。機密情報をファイルに保存することはセキュリティ上危険であるため、パスワードなどの重要な情報はスクリプト コードに書き込まないことをお勧めします。

既定では、Option Strict が IDE で無効になっています。

スクリプト コンポーネント プロジェクトの構造

スクリプト コンポーネントの威力は、インフラストラクチャ コードを生成して、記述する必要のあるコード量を減らす機能にあります。この機能を実現するには、入力と出力、およびその列とプロパティが固定され、既知である必要があります。したがって、コンポーネントのメタデータに後で変更を加えた場合、記述したコードが無効になり、パッケージの実行中にコンパイル エラーが発生する可能性があります。

スクリプト コンポーネント プロジェクトのプロジェクト アイテムおよびクラス

コード デザイン モードに切り替えると、VSTA IDE が開き、ScriptMain プロジェクト アイテムが表示されます。ScriptMain プロジェクト アイテムには、編集可能な ScriptMain クラスが含まれています。このクラスは、スクリプトのエントリ ポイントとしての役割を果たし、ここにコードを記述します。このクラスのコード要素は、スクリプト タスクに対して選択したプログラミング言語に応じて異なります。

スクリプト プロジェクトには、次の 2 つの読み取り専用のプロジェクト アイテムが自動生成され、追加されます。

  • 次の 3 つのクラスを含む ComponentWrapper プロジェクト アイテム。

    • UserComponent クラス。ScriptComponent から継承され、データの処理およびパッケージとのやり取りに使用するメソッドおよびプロパティが含まれています。ScriptMain クラスは UserComponent クラスから継承されます。

    • Connections コレクション クラス。[スクリプト変換エディタ] の [接続マネージャ] ページで選択された、接続への参照が含まれています。

    • Variables コレクション クラス。[スクリプト変換エディタ][スクリプト] ページで、ReadOnlyVariable および ReadWriteVariables プロパティに入力された変数への参照が含まれています。

  • BufferWrapper プロジェクト アイテム。[スクリプト変換エディタ][入力および出力] ページで構成された各入力および出力に対して、ScriptBuffer から継承されたクラスが含まれています。これらの各クラスには、構成された入力列と出力列、およびそれらの列が含まれるデータ フロー バッファに対応する、型指定されたアクセサ プロパティが含まれています。

これらのオブジェクト、メソッド、およびプロパティの使用方法については、「スクリプト コンポーネントのオブジェクト モデルについて」を参照してください。特定の種類のスクリプト コンポーネントで、これらのクラスのメソッドおよびプロパティを使用する方法については、セクション「その他のスクリプト コンポーネントの例」を参照してください。サンプルについてのトピックでは、完全なコード例も示します。

スクリプト コンポーネントを変換として構成すると、ScriptMain プロジェクト アイテムに次のコードが自動生成されます。

' Microsoft SQL Server Integration Services Script Component
' Write scripts using Microsoft Visual Basic 2008.
' ScriptMain is the entry point class of the script.

Imports System
Imports System.Data
Imports System.Math
Imports Microsoft.SqlServer.Dts.Pipeline.Wrapper
Imports Microsoft.SqlServer.Dts.Runtime.Wrapper

<Microsoft.SqlServer.Dts.Pipeline.SSISScriptComponentEntryPointAttribute> _
<CLSCompliant(False)> _
Public Class ScriptMain
    Inherits UserComponent

    Public Overrides Sub PreExecute()
        MyBase.PreExecute()
        '
        ' Add your code here for preprocessing or remove if not needed
        '
    End Sub

    Public Overrides Sub PostExecute()
        MyBase.PostExecute()
        '
        ' Add your code here for postprocessing or remove if not needed
        ' You can set read/write variables here, for example:
        ' Me.Variables.MyIntVar = 100
        '
    End Sub

    Public Overrides Sub Input0_ProcessInputRow(ByVal Row As Input0Buffer)
        '
        ' Add your code here
        '
    End Sub

End Class
/* Microsoft SQL Server Integration Services user script component
*  Write scripts using Microsoft Visual C# 2008.
*  ScriptMain is the entry point class of the script.*/

using System;
using System.Data;
using Microsoft.SqlServer.Dts.Pipeline.Wrapper;
using Microsoft.SqlServer.Dts.Runtime.Wrapper;

[Microsoft.SqlServer.Dts.Pipeline.SSISScriptComponentEntryPointAttribute]
public class ScriptMain : UserComponent
{

    public override void PreExecute()
    {
        base.PreExecute();
        /*
          Add your code here for preprocessing or remove if not needed
        */
    }

    public override void PostExecute()
    {
        base.PostExecute();
        /*
          Add your code here for postprocessing or remove if not needed
          You can set read/write variables here, for example:
          Variables.MyIntVar = 100
        */
    }

    public override void Input0_ProcessInputRow(Input0Buffer Row)
    {
        /*
          Add your code here
        */
    }

}

スクリプト コンポーネント プロジェクトのその他のプロジェクト アイテム

スクリプト コンポーネント プロジェクトには、既定の ScriptMain アイテム以外のアイテムを格納できます。プロジェクトには、クラス、モジュール、コード ファイル、およびフォルダを追加できます。また、フォルダを使用してアイテムのグループを整理できます。

追加したすべてのアイテムは、パッケージ内部に保存されます。

スクリプト コンポーネント プロジェクトの参照

参照をマネージ アセンブリに追加するには、[プロジェクト エクスプローラ] でスクリプト タスク プロジェクトを右クリックし、[参照の追加] をクリックします。詳細については、「スクリプティング ソリューションでの他のアセンブリの参照」を参照してください。

注意注意

プロジェクト参照は、VSTA IDE の [クラス ビュー] または [プロジェクト エクスプローラ] で表示できます。どちらのウィンドウも [表示] メニューから開きます。新しい参照は、[プロジェクト] メニュー、[プロジェクト エクスプローラ]、または [クラス ビュー] から追加できます。

スクリプト コンポーネント内でのパッケージとの対話

スクリプト コンポーネント内で記述するカスタム スクリプトは、自動生成された基本クラス内の、厳密に型指定されたアクセサを使用して、コンポーネントに含まれているパッケージの変数や接続マネージャにアクセスし、それらを使用できます。ただし、変数および接続マネージャをスクリプトで使用できるようにするには、コード デザイン モードに切り替える前に、その両方を設定する必要があります。また、スクリプト コンポーネントのコードから、イベントを発生させたり、ログ記録を実行することもできます。

スクリプト コンポーネント プロジェクト内に自動生成されるプロジェクト アイテムには、パッケージと情報をやり取りするために、以下のオブジェクト、メソッド、およびプロパティが用意されています。

パッケージの機能

アクセス方法

変数

ComponentWrapper プロジェクト アイテムの Variables コレクション クラス内の、名前付きで型指定されたアクセサ プロパティを使用します。これは ScriptMain クラスの Variables プロパティを介して公開されています。

PreExecute メソッドでは、読み取り専用変数にのみアクセスできます。PostExecute メソッドでは、読み取り専用変数および読み取り/書き込み変数の両方にアクセスできます。

接続

ComponentWrapper プロジェクト アイテムの Connections コレクション クラス内の、名前付きで型指定されたアクセサ プロパティを使用します。これは ScriptMain クラスの Connections プロパティを介して公開されています。

イベント

ScriptMain クラスの ComponentMetaData プロパティおよび IDTSComponentMetaData100 インターフェイスの Fire<X> メソッドを使用して、イベントを発生させます。

ログ記録

ScriptMain クラスの Log メソッドを使用して、ログ記録を実行します。

スクリプト コンポーネントのデバッグ

スクリプト コンポーネントでは、ブレークポイントの使用はサポートされていません。そのため、コードをステップ スルーしてパッケージの実行中に値を検証することはできません。ただし、次の方法を使用することにより、スクリプト コンポーネントの実行を監視できます。

  • 実行を中断し、System.Windows.Forms 名前空間の MessageBox.Show メソッドを使用して、モーダル メッセージを表示します。デバッグが完了したら、このコードは削除してください。

  • 情報メッセージ、警告、およびエラーを発生させます。FireInformationFireWarningFireError の各メソッドでは、イベントの説明が Visual Studio の [出力] ウィンドウに表示されます。ただし、FireProgress メソッド、Console.Write メソッド、および Console.WriteLine メソッドでは、[出力] ウィンドウに情報は表示されません。FireProgress イベントからのメッセージが SSIS デザイナの [進行状況] タブに表示されます。詳細については、「スクリプト コンポーネントでのイベントの発生」を参照してください。

  • イベントまたはユーザー定義のメッセージを、有効なログ プロバイダに記録します。詳細については、「スクリプト コンポーネントでのログ記録」を参照してください。

データを変換先に保存せずに、変換元または変換として構成されたスクリプト コンポーネントの出力を調べるだけの場合は、行数変換 を使用してデータ フローを終了し、スクリプト コンポーネントの出力にデータ ビューアをアタッチできます。データ ビューアの詳細については、「データ フローのデバッグ」を参照してください。

概要

スクリプト コンポーネントのコーディングの詳細については、このセクションの次のトピックを参照してください。

Integration Services のアイコン (小) 最新の Integration Services の入手

マイクロソフトが提供する最新のダウンロード、アーティクル、サンプル、ビデオ、およびコミュニティで選択されたソリューションについては、MSDN または TechNet の Integration Services のページを参照してください。

これらの更新が自動で通知されるようにするには、ページの RSS フィードを購読します。