SQL アダプターを使用して、大きなデータ型を持つテーブルとビューに対する操作を実行する
SQL アダプターを使用すると、アダプター クライアントは、大きなデータ型 (varchar(max)、nvarchar(max)、または varbinary(max) の列のデータを読み取って更新できます。 このような列からデータを読み取るために、アダプター クライアントは Select 操作を使用できます。 このような列にデータを挿入または更新するために、アダプターは Set<column_name> 操作を公開します。ここで、 <column_name> は varchar(max)、nvarchar(max)、または varbinary(max) 型の列の名前です。
さらに、SQL Server 2008 では、varbinay(max) 列にテキスト ドキュメントや画像などの非構造化データを格納させることができます。 このような非構造化データは FILESTREAM データと呼ばれます。 FILESTREAM データは、ファイル システム上のファイルとして格納できます。 SQL アダプターを使用すると、クライアントは varbinary(max) 型の列に FILESTREAM データを入力できます。 FILESTREAM ストレージの詳細については、「 FILESTREAM の概要」を参照してください。
このトピックでは、FILESTREAM データを挿入または更新するために、SQL Serverを実行しているコンピューターとアダプター クライアントを実行しているコンピューターで実行する必要がある特定のタスクについて説明します。 このトピックでは、FILESTREAM データを挿入するための set<column_name> 操作の実行手順についても説明します。
Note
ユーザー定義型の列を持つテーブルに対して操作を実行する場合は、アプリケーションの開発を開始する前 に、「SQL アダプターを使用して User-Defined 型を持つテーブルとビュー に対する操作」を参照してください。
前提条件
SQL Serverを実行しているコンピューターとアダプター クライアントを実行しているコンピューターで、次のタスクを実行する必要があります。
SQL Serverを実行しているコンピューターで
SQL Server インスタンスで FILESTREAM を有効にする必要があります。 詳細については、「https://go.microsoft.com/fwlink/?LinkId=122486」を参照してください。
FILESTREAM 対応データベースを作成する必要があります。 詳細については、「https://go.microsoft.com/fwlink/?LinkId=122487」を参照してください。
FILESTREAM データを格納するためのテーブルが必要です。 詳細については、「https://go.microsoft.com/fwlink/?LinkId=122488」を参照してください。
SQL Server データベースをホストしているコンピューターで MSDTC を構成する必要があります。 MSDTC を構成する方法については、「SQL Server およびアダプター クライアントで MSDTC を構成する」を参照してください。
アダプター クライアントを実行しているコンピューターで
SQL Client Connectivity SDK がインストールされている必要があります。 SQL Client Connectivity SDK をインストールするには、SQL Server 2008 セットアップを実行し、ウィザードの [機能の選択] ページで [SQL Client Connectivity SDK] を選択します。 アダプターは、SQL Client Connectivity SDK と共にインストールされた sqlncli10.dll を使用して FILESTREAM 操作を実行します。
アダプター クライアントを実行しているコンピューターで MSDTC を構成する必要があります。 MSDTC を構成する方法については、「SQL Server およびアダプター クライアントで MSDTC を構成する」を参照してください。
これらのタスクを完了すると、2008 データベース テーブルに FILESTREAM データSQL Server挿入または更新するように設定されます。
このトピックでは、大規模なデータ型に対する操作について説明します
大きなデータ型を持つテーブルに対して Set<column_name> 操作を実行する方法を示すには、列 ID と Document を含むテーブル Records を取得します。 Id 列は uniqueidentifier 型で、GUID を受け取ります。 Document 列の型は VARBINARY(MAX) です。 ID 列に既に GUID '' があると438B7B4C-5491-409F-BCC1-78817C399EC3
します。 Document 列を更新するために、アダプターは SetDocument 操作を公開します。
Note
SQL Server 2008 では、FILESTREAM 操作を示すために、Document 列に FILESTREAM データを格納できると仮定します。
SQL Server データベースに対して操作を実行する方法
BizTalk Serverと共に SQL アダプターを使用してSQL Server データベースに対して操作を実行するには、「Sql アダプターを使用して BizTalk アプリケーションを開発するための構成要素」で説明されている手続き型タスクが含まれます。 大きなデータ型を持つテーブルに対して操作を実行するには、次のタスクを実行します。
BizTalk プロジェクトを作成し、set<column_name> 操作のスキーマを生成します。 このトピックでは、レコード テーブルの SetDocument 操作のスキーマを生成します。
SQL Server データベースからメッセージを送受信するためのメッセージを BizTalk プロジェクトに作成します。
レコード テーブルに対して SetDocument 操作を呼び出すオーケストレーションを作成します。
BizTalk プロジェクトをビルドして展開します。
物理送受信ポートを作成して BizTalk アプリケーションを構成します。
BizTalk アプリケーションを起動します。
このトピックでは、これらのタスクを実行する手順について説明します。
このトピックに基づくサンプル
このトピックに基づくサンプル FILESTREAMOperation は、BizTalk アダプター パックと共に提供されています。 詳細については、「 SQL アダプターのサンプル」を参照してください。
スキーマの生成
大きなデータ型の列の値を更新する方法を示すには、Records テーブルの SetDocument 操作のスキーマを生成します。 BizTalk プロジェクトを作成し、アダプター サービス アドインを使用してスキーマを生成する必要があります。 スキーマの生成方法の詳細については、「SQL アダプターを使用した Visual Studio でのSQL Server操作のメタデータの取得」を参照してください。
メッセージとメッセージの種類の定義
先に生成したスキーマは、オーケストレーションのメッセージに求められる "型" を記述します。 通常、メッセージは変数であり、対応するスキーマによって定義される型です。 オーケストレーションのメッセージを作成し、前の手順で生成したスキーマにリンクする必要があります。
メッセージを作成し、スキーマにリンクするには
BizTalk プロジェクトにオーケストレーションを追加します。 ソリューション エクスプローラーから BizTalk プロジェクト名を右クリックし、[追加] をポイントして、[新しい項目] をクリックします。 BizTalk オーケストレーションの名前を入力し、[ 追加] をクリックします。
BizTalk プロジェクトの [オーケストレーションの種類] ウィンドウを開きます (まだ表示されていない場合)。 これを行うには、[ 表示] をクリックし、[ その他のウィンドウ] をポイントして、[ オーケストレーション ビュー] をクリックします。
オーケストレーション ビューで、[ メッセージ] を右クリックし、[ 新しいメッセージ] をクリックします。
新しく作成したメッセージを右クリックし、[ プロパティ ウィンドウ] を選択します。
Message_1の [プロパティ] ウィンドウで、次の操作を行います。
プロパティ 目的 識別子 「 Request
」と入力しますメッセージ型 ドロップダウン リストから [ スキーマ] を展開し、[ SetOperation.TableOperation_dbo_Records.SetDocument] (SetOperation は BizTalk プロジェクトの名前) を選択します。 TableOperation_dbo_Recordsは、レコード テーブルに対する SetDocument 操作に対して生成されるスキーマです。 手順 2 を繰り返して、新しいメッセージを作成します。 新しいメッセージの [プロパティ ] ウィンドウで、次の操作を行います。
プロパティ 目的 識別子 「 Response
」と入力しますメッセージ型 ドロップダウン リストから [ スキーマ] を展開し、[ SetOperation.TableOperation_dbo_Records.SetDocumentResponse] を選択します。
オーケストレーションの設定
SQL Serverで操作を実行するためにBizTalk Serverを使用するには、BizTalk オーケストレーションを作成する必要があります。 このオーケストレーションでは、定義された受信場所に要求メッセージをドロップします。 SQL アダプターはこのメッセージを使用し、SQL Serverに渡します。 SQL Serverからの応答は別の場所に保存されます。 SQL Serverにメッセージを送信したり、応答を受信したりするには、[送信] 図形と [受信] 図形を含める必要があります。 SetDocument 操作のサンプル オーケストレーションは次のようになります。
メッセージ図形の追加
メッセージ図形ごとに次のプロパティを指定してください。 [図形] 列に一覧表示される名前は、単一のオーケストレーションに表示されるメッセージ図形の名前です。
図形 | 図形の種類 | プロパティ |
---|---|---|
ReceiveMessage | 受信 | - 名前を ReceiveMessage に設定する - アクティブ化を True に設定する |
SendMessage | Send | - 名前を SendMessage に設定する |
ReceiveResponse | 受信 | - 名前を ReceiveResponse に設定する - アクティブ化を False に設定する |
SendResponse | Send | - 名前を SendResponse に設定する |
ポートの追加
論理ポートごとに次のプロパティを指定してください。 [ポート] 列に表示される名前は、オーケストレーションに表示されるポートの名前です。
Port | プロパティ |
---|---|
MessageIn | - 識別子を MessageIn に設定する - Type を MessageInType に設定する - 通信パターンを一方向に設定する - 通信方向を受信に設定する |
LOBPort | - 識別子を LOBPort に設定する - 型を LOBPortType に設定する - 通信パターンを Request-Response に設定する - [通信の方向] を [送受信] に設定する |
ResponseOut | - 識別子を ResponseOut に設定する - Type を ResponseOutType に設定する - 通信パターンを一方向に設定する - [通信の方向] を [送信] に設定する |
アクション 図形のメッセージを指定し、ポートに接続する
次の表では、アクション図形のメッセージを指定し、メッセージをポートにリンクするために設定するプロパティとその値を指定します。 [図形] 列に表示される名前は、前述のオーケストレーションに表示されるメッセージ図形の名前です。
図形 | プロパティ |
---|---|
ReceiveMessage | - メッセージを要求に設定する - 操作を MessageIn.FileStream.Request に設定する |
SendMessage | - メッセージを要求に設定する - 操作を LOBPort.FileStream.Request に設定する |
ReceiveResponse | - メッセージを応答に設定する - 操作を LOBPort.FileStream.Response に設定する |
SendResponse | - メッセージを応答に設定する - 操作を ResponseOut.FileStream.Request に設定する |
これらのプロパティを指定すると、メッセージの図形とポートが接続され、オーケストレーションが完了します。
BizTalk ソリューションをビルドし、BizTalk Serverに展開する必要があります。 詳細については、「オーケストレーションの ビルドと実行」を参照してください。
BizTalk アプリケーションの構成
BizTalk プロジェクトを展開すると、先ほど作成したオーケストレーションが、BizTalk Server管理コンソールの [オーケストレーション] ウィンドウの下に一覧表示されます。 アプリケーションを構成するには、BizTalk Server管理コンソールを使用する必要があります。 チュートリアルについては、「 チュートリアル: 基本的な BizTalk アプリケーションの展開」を参照してください。
アプリケーションの構成には、次の作業が含まれます。
アプリケーションのホストの選択。
オーケストレーションで作成したポートを、BizTalk Server管理コンソールの物理ポートにマッピングします。 このオーケストレーションでは、次の操作を行う必要があります。
ハード ディスク上の場所と、要求メッセージをドロップする対応するファイル ポートを定義します。 BizTalk オーケストレーションは要求メッセージを使用し、SQL Server データベースに送信します。
ハード ディスク上の場所と、BizTalk オーケストレーションがSQL Server データベースからの応答を含む応答メッセージを削除する対応するファイル ポートを定義します。
SQL Server データベースにメッセージを送信する物理 WCF-Custom または WCF-SQL 送信ポートを定義します。 また、送信ポートでアクションを指定する必要があります。 ポートを作成する方法については、「 SQL アダプターへの物理ポート バインドを手動で構成する」を参照してください。
重要
FILESTREAM データを入力する操作は、トランザクション内で実行する必要があります。 そのため、WCF-Custom または WCF-SQL 送信ポートで UseAmbientTransaction バインド プロパティが True に設定されていることを確認します。 バインディング プロパティの詳細については、「BizTalk Adapter for SQL Server adapter Binding Properties」を参照してください。
重要
FILESTREAM データを挿入する操作を実行するには、常に Windows 認証を使用して、WCF-Custom または WCF-SQL 送信ポートのSQL Serverに接続する必要があります。 そのため、ポートのプロパティ ダイアログ ボックスの [ 資格情報 ] タブで、[ シングル サインオンを使用しない ] オプションを選択し、ユーザー名とパスワードは空白のままにします。
Note
アダプター サービス BizTalk プロジェクト アドインを使用してスキーマを生成すると、ポートに関する情報と、それらのポートに設定するアクションを含むバインド ファイルも作成されます。 BizTalk Server管理コンソールからこのバインド ファイルをインポートして、送信ポート (送信呼び出しの場合) または受信ポート (受信呼び出し用) を作成できます。 詳細については、「 SQL アダプターを使用するようにポート バインド ファイルを使用して物理ポート バインドを構成する」を参照してください。
アプリケーションの起動
レコード テーブルで SetDocument 操作を実行するには、BizTalk アプリケーションを起動する必要があります。 BizTalk アプリケーションを起動する手順については、「オーケストレーションを 開始する方法」を参照してください。
この段階で、次のことを確認します。
オーケストレーションの要求メッセージを受信する FILE 受信ポートが実行されています。
オーケストレーションからの応答メッセージを受信する FILE 送信ポートが実行されています。
SQL Server データベースにメッセージを送信する WCF-Custom または WCF-SQL 送信ポートが実行されています。
操作の BizTalk オーケストレーションが実行されています。
操作の実行
アプリケーションを実行した後、FILE 受信場所に要求メッセージをドロップする必要があります。 要求メッセージのスキーマは、前に生成した SetDocument 操作のスキーマに準拠している必要があります。 たとえば、ドキュメント列を更新するための要求メッセージは次のとおりです。
<SetDocument xmlns="http://schemas.microsoft.com/Sql/2008/05/TableOp/dbo/Records">
<Filter>WHERE Id='438B7B4C-5491-409F-BCC1-78817C399EC3'</Filter>
<Data>UwBlAHQAdgBfAHYAYQByAGIAaQBuAGEAcgB5AE0AQQBYAA==</Data>
</SetDocument>
重要
要素には Filter
、アダプターがレコードを更新する WHERE 句を含める必要があります。 要素には Data
、Document 列に挿入する base64 エンコード値が含まれている必要があります。
この要求メッセージは、指定した値で Document 列を更新します。 オーケストレーションによってメッセージが使用され、SQL Server データベースに送信されます。 SQL Server データベースからの応答は、オーケストレーションの一部として定義されている他の FILE の場所に保存されます。 たとえば、上記の要求メッセージに対するSQL Server データベースからの応答は次のようになります。
<?xml version="1.0" encoding="utf-8" ?>
<SetDocumentResponse xmlns="http://schemas.microsoft.com/Sql/2008/05/TableOp/dbo/Records" />
アダプターは 、Set<column_name 操作に対して空の応答を> 送信します。
ベスト プラクティス
BizTalk プロジェクトを展開して構成したら、構成設定をバインド ファイルと呼ばれる XML ファイルにエクスポートできます。 バインド ファイルを生成したら、ファイルから構成設定をインポートして、同じオーケストレーションの送信ポートや受信ポートなどの項目を作成する必要がないようにすることができます。 バインド ファイルの詳細については、「アダプター バインドを 再利用する」を参照してください。