IBM DB2 サブスクライバ
Microsoft SQL Server 2005 は、Microsoft Host Integration Server に含まれている OLE DB プロバイダを経由した IBM DB2/AS 400、DB2/MVS、および DB2/Universal Database へのプッシュ サブスクリプションをサポートします。
メモ : |
---|
Microsoft OLE DB Provider for DB2 は、Itanium ベースのアーキテクチャでは現在サポートされていません (以前は IA-64 ベース)。したがって、SQL Server レプリケーションは、このプラットフォーム上の DB2 サブスクライバへのデータのレプリケーションをサポートしていません。 |
IBM DB2 サブスクライバの構成
IBM DB2 サブスクライバを構成するには、次の手順を実行してください。
Microsoft OLE DB Provider for DB2 の最新バージョンをディストリビュータにインストールします。
- SQL Server 2005 Enterprise Edition を使用している場合は、この Microsoft Web サイトからプロバイダをダウンロードできます。「Microsoft OLE DB Provider for DB2」を検索してください。
- SQL Server 2005 Standard Edition を使用している場合は、Microsoft Host Integration Services (HIS) サーバーの最新バージョンをインストールしてください。この製品にプロバイダが含まれています。
プロバイダのインストールに加えて、データ アクセス ツールをインストールすることをお勧めします。データ アクセス ツールは次の手順で使用します (データ アクセス ツールは、Enterprise Edition のダウンロードで既定でインストールされます)。データ アクセス ツールのインストールと使用に関する詳細については、プロバイダのドキュメントまたは HIS のドキュメントを参照してください。
サブスクライバの接続文字列を作成します。この接続文字列は任意のテキスト エディタで作成できますが、データ アクセス ツールを使用することをお勧めします。データ アクセス ツールで接続文字列を作成するには、次の手順を実行します。
- [スタート] ボタンをクリックし、[プログラム] をポイントします。次に、[Microsoft OLE DB Provider for DB2] をポイントし、[データ アクセス ツール] をクリックします。
- [データ アクセス ツール] で、手順に従って DB2 サーバーに関する情報を指定します。このツールを完了すると、関連付けられている接続文字列を使用してユニバーサル データ リンク (UDL) が作成されます (レプリケーションでは、実際にはこの UDL は使用されず、接続文字列が使用されます)。
- 接続文字列にアクセスします。[データ アクセス ツール] で UDL を右クリックし、[接続文字列の表示] を選択します。
接続文字列は、次のようになります (この例は、読みやすくするために改行されています)。
Provider=DB2OLEDB;Initial Catalog=MY_SUBSCRIBER_DB;Network Transport Library=TCP;Host CCSID=1252; PC Code Page=1252;Network Address=MY_SUBSCRIBER;Network Port=50000;Package Collection=MY_PKGCOL; Default Schema=MY_SCHEMA;Process Binary as Character=False;Units of Work=RUW;DBMS Platform=DB2/NT; Persist Security Info=False;Connection Pooling=True;
文字列のほとんどのオプションは構成している DB2 サーバー固有の値になりますが、Process Binary as Character オプションは、常に False に設定する必要があります。サブスクリプション データベースを識別するには、Initial Catalog オプションに値を入力する必要があります。接続文字列は、サブスクリプションを作成するときに、サブスクリプションの新規作成ウィザードに入力します。
スナップショット パブリケーションまたはトランザクション パブリケーションを作成して、SQL Server 以外のサブスクライバに対して有効にしてから、サブスクライバに対してプッシュ サブスクリプションを作成します。詳細については、以下を参照してください。
- SQL Server Management Studio: SQL Server 以外のサブスクライバのサブスクリプションを作成する方法 (SQL Server Management Studio)
- レプリケーション Transact-SQL プログラミング : SQL Server 以外のサブスクライバに対するサブスクリプションを作成する方法 (レプリケーション Transact-SQL プログラミング)
必要に応じて、1 つ以上のアーティクルに対してカスタム作成スクリプトを指定します。テーブルがパブリッシュされると、そのテーブルに対して CREATE TABLE スクリプトが作成されます。SQL Server 以外のサブスクライバでは、このスクリプトは Transact-SQL 言語で作成されます。その後、このスクリプトは、サブスクライバで適用される前に、ディストリビューション エージェントによって、より汎用的な SQL 言語に翻訳されます。カスタム作成スクリプトを指定するには、既存の Transact-SQL スクリプトを変更するか、DB2 SQL 言語を使用する完全なスクリプトを作成します。DB2 スクリプトを作成する場合は、bypass_translation ディレクティブを使用して、ディストリビューション エージェントがサブスクライバでスクリプトを翻訳しないで適用できるようにします。
スクリプトはさまざまな理由によって変更することができますが、最も一般的な理由はデータ型マッピングの変更です。詳細については、このトピックの「データ型マッピングに関する注意点」を参照してください。Transact-SQL スクリプトを変更する場合、変更はデータ型マッピングの変更に制限する必要があります (また、スクリプトにコメントを含めることはできません)。より大きな変更を行う必要がある場合は、DB2 スクリプトを作成します。
アーティクル スクリプトを変更し、それをカスタム作成スクリプトとして指定するには- スナップショットがパブリケーションに対して生成されたら、パブリケーションのスナップショット フォルダに移動します。
- MyArticle.sch など、アーティクルと同じ名前が付いた .sch ファイルを検索します。
- メモ帳やその他のテキスト エディタを使用して、このファイルを開きます。
- ファイルを変更し、別のディレクトリに保存します。
- sp_changearticle を実行し、creation_script プロパティに対してファイルのパスと名前を指定します。詳細については、「sp_changearticle (Transact-SQL)」を参照してください。
アーティクル スクリプトを作成し、それをカスタム作成スクリプトとして指定するには
- DB2 SQL 言語を使用してアーティクル スクリプトを作成します。ファイルの最初の行が bypass_translation であり、この行に他に記述がないことを確認します。
- sp_changearticle を実行し、creation_script プロパティに対してファイルのパスと名前を指定します。
IBM DB2 サブスクライバに関する注意点
「SQL Server 以外のサブスクライバ」で説明した注意点の他に、DB2 サブスクライバへのレプリケートでは以下の問題に注意してください。
- レプリケートされた各テーブルのデータとインデックスは、DB2 テーブルスペースに割り当てられます。DB2 テーブルスペースのページ サイズは、テーブルスペースに属するテーブルの列の最大数と最大行サイズを制御します。レプリケートされたテーブルに関連付けられたテーブルスペースが、テーブルのレプリケート済み列数と最大行サイズに基づいて、適切であることを確認します。
- テーブル内の 1 つ以上の主キー列がデータ型 DECIMAL(32-38, 0-38) または NUMERIC(32-38, 0-38) である場合は、トランザクション レプリケーションを使用して DB2 サブスクライバにテーブルをパブリッシュしないでください。トランザクション レプリケーションは、主キーを使用して行を識別します。この結果、これらのデータ型はサブスクライバでは VARCHAR(41) にマップされるため、エラーになります。これらのデータ型を使用する主キーを持つテーブルは、スナップショット レプリケーションを使用してパブリッシュできます。
- サブスクライバでテーブルを事前作成する場合は、レプリケーションによって作成するのではなく、replication support only オプションを使用します。詳細については、「スナップショットを使用しないトランザクション サブスクリプションの初期化」を参照してください。
- SQL Server では、DB2 よりも長いテーブル名と列名を使用できます。
- サブスクライバの DB2 のバージョンでサポートされているテーブル名よりも長い名前のテーブルがパブリケーション データベースに含まれている場合、destination_table アーティクル プロパティに代替名を指定します。パブリケーションの作成時のプロパティの設定の詳細については、「パブリケーションを作成してアーティクルを定義する方法 (SQL Server Management Studio)」および「アーティクルを定義する方法 (レプリケーション Transact-SQL プログラミング)」を参照してください。
- 代替列名を指定することはできません。パブリッシュするテーブルに、サブスクライバの DB2 のバージョンでサポートされている列名よりも長い列名がテーブルに含まれていないことを確認する必要があります。
SQL Server から IBM DB2 へのデータ型マッピング
次の表は、IBM DB2 を実行しているサブスクライバへのデータのレプリケーションで使用される、データ型のマッピングを示しています。
SQL Server データ型 | IBM DB2 データ型 |
---|---|
BIGINT |
DECIMAL(19,0) |
BINARY(1-254) |
CHAR(1-254) FOR BIT DATA |
BINARY(255-8000) |
VARCHAR(255-8000) FOR BIT DATA |
BIT |
SMALLINT |
CHAR(1-254) |
CHAR(1-254) |
CHAR(255-8000) |
VARCHAR(255-8000) |
DATETIME |
TIMESTAMP |
DECIMAL(1-31, 0-31) |
DECIMAL(1-31, 0-31) |
DECIMAL(32-38, 0-38) |
VARCHAR(41) |
DOUBLE PRECISION |
DOUBLE |
FLOAT |
FLOAT |
IMAGE |
VARCHAR(0) FOR BIT DATA1 |
INT |
INT |
MONEY |
DECIMAL(19,4) |
NCHAR(1-4000) |
VARCHAR(1-4000) |
NTEXT |
VARCHAR(0)1 |
NUMERIC(1-31, 0-31) |
DECIMAL(1-31,0-31) |
NUMERIC(32-38, 0-38) |
VARCHAR(41) |
NVARCHAR(1-4000) |
VARCHAR(1-4000) |
NVARCHAR(MAX) |
VARCHAR(0)1 |
REAL |
REAL |
SMALLDATETIME |
TIMESTAMP |
SMALLINT |
SMALLINT |
SMALLMONEY |
DECIMAL(10,4) |
SQL_VARIANT |
N/A |
SYSNAME |
VARCHAR(128) |
TEXT |
VARCHAR(0)1 |
TIMESTAMP |
CHAR(8) FOR BIT DATA |
TINYINT |
SMALLINT |
UNIQUEIDENTIFIER |
CHAR(38) |
VARBINARY(1-8000) |
VARCHAR(1-8000) FOR BIT DATA |
VARCHAR(1-8000) |
VARCHAR(1-8000) |
VARBINARY(MAX) |
VARCHAR(0) FOR BIT DATA1 |
VARCHAR(MAX) |
VARCHAR(0)1 |
XML |
VARCHAR(0)1 |
1 VARCHAR(0) へのマッピングの詳細については、次のセクションを参照してください。
データ型マッピングに関する注意点
DB2 サブスクライバにレプリケートするときは、次に示すデータ型のマッピングに関する問題点について考慮してください。
- SQL Server の CHAR、VARCHAR、BINARY、および VARBINARY がそれぞれ DB2 の CHAR、VARCHAR、CHAR FOR BIT DATA、および VARCHAR FOR BIT DATA にマップされると、DB2 データ型の長さはレプリケーションによって SQL Server データ型と同じ長さに設定されます。
これによって、DB2 ページ サイズ制約が行の最大サイズに対応するために十分な大きさである限り、生成されるテーブルはサブスクライバで正常に作成できます。DB2 データベースにアクセスするために使用されるログインに、DB2 にレプリケートされているテーブルに対して十分なサイズを持つテーブル スペースにアクセスするための権限があることを確認します。 - DB2 は、32 KB の VARCHAR 列をサポートできます。このため、SQL Server の LOB 列の一部は問題なく DB2 VARCHAR 列にマップできる可能性があります。ただし、レプリケーションが DB2 に対して使用する OLE DB プロバイダでは、SQL Server の LOB を DB2 の LOB にマップする処理はサポートしていません。このため、SQL Server の TEXT、VARCHAR(MAX)、NTEXT、および NVARCHAR(MAX) 列は、生成される作成スクリプトでは VARCHAR(0) にマップされます。長さの値が 0 の場合は、サブスクライバにスクリプトを適用する前に、適切な値に変更する必要があります。データ型の長さが変更されない場合、DB2 サブスクライバでテーブルの作成を試みると、DB2 でエラー 604 が発生します (エラー 604 は、データ型の有効桁数または長さの属性が有効でないことを示します)。
レプリケートするソース テーブルの情報に基づいて、SQL Server の LOB を可変長の DB2 項目にマップすることが適切であるかどうかを判断し、カスタム作成スクリプトで適切な最大長を指定してください。カスタム作成スクリプトの指定の詳細については、このトピックの「IBM DB2 サブスクライバの構成」の手順 5. を参照してください。メモ : DB2 のデータ型に対して指定された長さは、他の列の長さと組み合わせた場合、テーブル データが割り当てられている DB2 テーブルスペースに基づいた最大行サイズを超えることはできません。 - SQL Server の NCHAR と NVARCHAR を DB2 の CHAR と VARCHAR にレプリケートする場合、レプリケーションでは SQL Server のデータ型に対するものと同じ長さ指定子が DB2 のデータ型に対して使用されます。ただし、データ型の長さが、生成された DB2 テーブルには小さくなりすぎる可能性があります。
DB2 の環境によっては、SQL Server CHAR データ項目は、1 バイト文字に限定されないことがあります。CHAR または VARCHAR 項目の長さに関しては、この点を考慮する必要があります。また、必要に応じて、シフト イン文字とシフト アウト文字についても考慮する必要があります。NCHAR 列と NVARCHAR 列を持つテーブルをレプリケートする場合は、カスタム作成スクリプトで、データ型の最大長として、より大きな値を指定することが必要になる場合があります。カスタム作成スクリプトの指定の詳細については、このトピックの「IBM DB2 サブスクライバの構成」の手順 5. を参照してください。
参照
概念
SQL Server 以外のサブスクライバ
パブリケーションのサブスクライブ