IBM DB2 訂閱者
Microsoft 透過 Microsoft Host Integration Server 所含的 OLE DB 提供者,SQL Server 2005 支援向 IBM DB2/AS 400、DB2/MVS 和 DB2/Universal Database 的提取訂閱。
附註: |
---|
在以 Itanium (以前稱為 IA-64) 為基礎的架構上目前不支援 Microsoft OLE DB Provider for DB2。因此,在此平台上,SQL Server 複寫不支援將資料複寫至「DB2 訂閱者」。 |
設定 IBM DB2 訂閱者
若要設定「IBM DB2 訂閱者」,請遵循下列步驟:
在「散發者」上安裝「DB2 的 Microsoft OLE DB 提供者」的最新版本:
- 如果您使用的是 SQL Server 2005 Enterprise Edition,則可以在這個 Microsoft 網站上搜尋 "Microsoft OLE DB Provider for DB2" 來下載提供者。
- 如果您使用的是 SQL Server 2005 Standard Edition,請安裝 Microsoft Host Integration Services (HIS) 伺服器的最新版本,其中就包含提供者。
除了安裝提供者外,建議您同時安裝「資料存取工具」,該工具將在下一步中用到 (依預設,它會隨 Enterprise 版的下載一起安裝)。如需有關安裝和使用「資料存取工具」的詳細資料,請參閱提供者文件集或 HIS 文件集。
為「訂閱者」建立連接字串。在任何文字編輯器中都可建立連接字串,但建議您使用「資料存取工具」。若要在「資料存取工具」中建立字串:
- 依序按一下 [開始]、[程式集] 和 [DB2 的 Microsoft OLE DB 提供者],然後再按 [資料存取工具]。
- 遵循 [資料存取工具] 中的步驟提供有關 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,但 [將二進位視為字元處理] 選項應永遠設定為 False。[初始資料目錄] 選項需要一個數值來指定訂閱資料庫。在您建立訂閱時,將在「新增訂閱精靈」中輸入連接字串。
建立快照集或交易式發行集,並為非 SQL Server 訂閱者啟用,然後再為訂閱者建立發送訂閱。如需詳細資訊,請參閱:
- SQL Server Management Studio: 如何:為非 SQL Server 訂閱者建立訂閱 (SQL Server Management Studio)
- 複寫 Transact-SQL 程式設計:<How to: Create a Subscription for a Non-SQL Server Subscriber (Replication Transact-SQL Programming)>
可以選擇為一或多個發行項指定自訂建立指令碼。發行資料表時,將為該資料表建立一個 CREATE TABLE 指令碼。對於非 SQL Server 訂閱者,指令碼將以 Transact-SQL 用語建立,然後在「訂閱者」端被套用之前,透過「散發代理程式」將其翻譯為比較一般的 SQL 用語。若要指定自訂建立指令碼,請修改現有的 Transact-SQL 指令碼或建立使用 DB2 SQL 用語的完整指令碼;如果已建立 DB2 指令碼,請使用 bypass_translation 指示詞,以便「散發代理程式」無需進行翻譯便可在「發行者」端套用指令碼。
有多種情況下會需要修改指令碼,但最常見的原因是改變資料類型對應。如需詳細資訊,請參閱本主題中的<資料類型對應考量>一節。若要修改 Transact-SQL 指令碼,請將變更限制為資料類型對應變更 (且指令碼不應包含任何註解)。如果需要作大量變更,請建立 DB2 指令碼。
若要修改發行項指令碼並作為自訂建立指令碼提供- 為發行集產生快照集後,瀏覽至發行集的快照集資料夾。
- 找到與發行項名稱相同的 .sch 檔案,例如 MyArticle.sch。
- 使用「記事本」或其他文字編輯器開啟此檔案。
- 修改檔案並將其儲存至其他目錄。
- 執行 sp_changearticle,並指定 creation_script 屬性的檔案路徑與名稱。如需詳細資訊,請參閱<sp_changearticle (Transact-SQL)>。
若要建立發行項指令碼並作為自訂建立指令碼提供
- 使用 DB2 SQL 用語建立發行項指令碼。確定檔案的第一行為 bypass_translation,且該行上除此之外無其他內容。
- 執行 sp_changearticle,並指定 creation_script 屬性的檔案路徑與名稱。
IBM DB2 訂閱者考量
複寫至「DB2 訂閱者」時,除了<非 SQL Server 訂閱者>主題中涵蓋的考量外,還需考慮以下幾個問題:
- 每個已複寫資料表的資料與索引將指定給 DB2 資料表空間。DB2 資料表空間的頁面大小,控制資料表空間所屬資料表的最大資料行行數以及最大資料列大小。根據複寫的資料行數與資料表的最大資料列大小,確定與複寫資料表相關聯的資料表空間是否適當。
- 如果資料表中一或多個主索引鍵資料行的資料類型為 DECIMAL(32-38, 0-38) 或 NUMERIC(32-38, 0-38),則不要使用交易式複寫將資料表發行至「DB2 訂閱者」。交易式複寫使用主索引鍵識別資料列;這可能會導致失敗,因為這些資料類型對應至「訂閱者」端的 VARCHAR(41)。含有可使用這些資料類型之主索引鍵的資料表可以使用快照式複寫加以發行。
- 如果您要在「訂閱者」端預先建立資料表,請不要由複寫來建立,而是使用僅支援複寫選項。如需詳細資訊,請參閱<不使用快照集初始化交易式訂閱>。
- 相對於 DB2,SQL Server 允許使用更長的資料表名稱和資料行名稱:
- 如果發行集資料庫中的資料表名稱比「訂閱者」端 DB2 版本支援的資料表名稱長,請為 destination_table 發行項屬性指定替代名稱。如需在建立發行集時設定屬性的詳細資訊,請參閱<如何:建立發行集並定義發行項 (SQL Server Management Studio)>和<How to: Define an Article (Replication Transact-SQL Programming)>。
- 不可能指定替代資料行名稱。您必須確定已發行資料表中的資料行名稱比「訂閱者」端 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 大型物件資料行正確對應至 DB2 VARCHAR 資料行。但是,複寫用於 DB2 的 OLE DB 提供者不支援將 SQL Server 大型物件對應至 DB2 大型物件。因此,在產生的建立指令碼中,SQL Server TEXT、VARCHAR(MAX)、NTEXT 和 NVARCHAR(MAX) 資料行將對應至 VARCHAR(0)。長度值 0 必須在將指令碼套用至「訂閱者」之前變更為適當值。如果資料類型長度未變更,則嘗試在「DB2 訂閱者」端建立資料表時,DB2 將產生錯誤 604 (表示資料類型的有效位數或長度屬性無效)。
根據您對要複寫之來源資料表的瞭解,判斷是否適合將 SQL Server 大型物件對應至可變長度的 DB2 項目,並在自訂建立指令碼中指定適當的最大長度。如需有關指定自訂建立指令碼的資訊,請參閱本主題中<設定 IBM DB2 訂閱者>一節中的步驟 5。附註: 指定的 DB2 類型長度與其他資料行長度的組合,不得超過由資料表資料指派到的 DB2 資料表空間確定之最大資料列大小。 - 在將 SQL Server NCHAR 和 NVARCHAR 複寫至 DB2 CHAR 和 VARCHAR 時,複寫對 DB2 類型與 SQL Server 類型使用相同的長度規範。但是,資料類型長度對於產生的 DB2 資料表可能太小。
在某些 DB2 環境中,SQL Server CHAR 資料項目未限制為單位元組字元,所以 CHAR 或 VARCHAR 項目的長度必須將此考慮在內。如果需要 shift in 和 shift out 字元,您還必須考慮到它們。如果您要複寫含有 NCHAR 和 NVARCHAR 資料行的資料表,可能需要為自訂建立指令碼中的資料類型指定較大的最大長度。如需有關指定自訂建立指令碼的資訊,請參閱本主題中<設定 IBM DB2 訂閱者>一節中的步驟 5。