您目前已離線,請等候您的網際網路重新連線

FIX: 您卸除在發行者端的資料表的外部索引鍵條件約束不是放在資料表時在 SQL Server 2005 合併式複寫訂閱者

重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。

按一下這裡查看此文章的英文版本:938825
BUG #: 50001169 (SQL Hotfix)

Microsoft 為一個可下載檔案散佈 Microsoft SQL Server 2005 的修正程式。因為修正程式是累積,每個新版本包含所有 Hotfix 及先前的 SQL Server 2005 隨附所有安全性修正程式都修正發行。
結論
本文將告訴您下列關於此 Hotfix 版本:
  • Hotfix 套件所修正的問題
  • 安裝 Hotfix 套件的先決條件
  • 是否您必須重新啟動電腦安裝 Hotfix 套件之後
  • 是否 Hotfix 套件就會取代任何其他 Hotfix 套件
  • 您必須在是否做任何登錄變更
  • 包含在 Hotfix 套件中的檔案
徵狀
在 Microsoft SQL Server 2005 合併式複寫,請在發行者端放在資料表上的外部索引鍵條件約束。同步發行者和訂閱者之間資料之後複寫合併代理程式不會不在 「 訂閱者端刪除外部索引鍵的條件約束,在資料表上。

當 dbo 結構描述不屬於相關的資料表在發行者與訂閱者處時,就會發生這個問題。
發生的原因
複寫合併代理程式在 「 訂閱者端執行的不正確的查詢,就會發生這個問題。當查詢執行複寫合併代理程式時,OBJECT_ID 函數會傳回 NULL。然後,EXISTS IF 陳述式會傳回 FALSE。因此,複寫合併代理程式不會執行 DROP CONSTRAINT 陳述式。

下列是在 「 訂閱者端執行的複寫合併代理程式查詢的範例:
IF EXISTS (SELECT * from sysconstraints WHERE constid = OBJECT_ID (N'[FK_DETAIL_TO_MASTER]')) IF OBJECT_ID (N'[Test].[Detail]') IS NOT NULL EXEC ('ALTER TABLE [Test].[Detail] DROP CONSTRAINT FK_DETAIL_TO_MASTER')
解決方案

更新資訊

此 Hotfix 併入累積更新套件 2 (建置 3175) 中的 SQL Server 2005 Service Pack 2 (SP2)。

如果要解決本文所述的問題,請依照下列步驟執行:
  1. 安裝 SQL Server 2005 SP2。
  2. 為 SQL Server 2005 SP2 安裝累積更新套件 2 (建置 3175)。
如需詳細資訊按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中 「 文件]:
913089如何取得最新的 Service Pack,SQL Server 2005 的
936305SQL Server 2005 Service Pack 2 的累積更新套件 2 是可用

Hotfix 資訊

Microsoft 提供支援的 Hotfix。不過,此 Hotfix 旨在修正本文中所述隨問題。只會發生此特定問題的系統套用此 Hotfix。這個 Hotfix 可能會接受額外的測試。因此,如果您不會嚴重影響這個問題,我們建議您等候下一個包含此 Hotfix 的軟體更新。

如果此 Hotfix 可供下載,您可在本知識庫文件的頂端找到「 可用的 Hotfix 下載 」區段。如果本節 Does Not Appear 請連絡[ Microsoft 客戶服務 ] 和 [ 支援 ] 以取得此 Hotfix。

附註如果發生其他問題,或如果需要任何疑難排解,您可能必須建立個別的服務要求。和此 Hotfix 無關的額外支援問題適用一般的支援費用。如需 Microsoft 客戶服務支援部門電話號碼的完整清單或要建立個別的服務要求,請造訪下列 Microsoft 網站:附註「 下載 Hotfix 」 表單會顯示此 Hotfix 會出現,以供使用的語言。如果您沒有看到您的語言,是因為此 Hotfix 是不適用您的語言。

必要條件

您必須具有要套用這個 Hotfix 安裝 SQL Server 2005 SP2。

重新啟動資訊

您沒有重新啟動電腦。

Hotfix 取代資訊

此 Hotfix 不會取代任何其他 Hotfix。

登錄資訊

您沒有變更登錄。

檔案資訊

此 Hotfix 包含只需修正本文所列問題的那些檔案。此 Hotfix 並未包含必須將產品完整更新至最新版組建的所有檔案。

此 Hotfix 的英文版在檔案屬性 (或更新版本的檔案屬性) 如下列表格中所列。這些檔案的日期和時間為 Coordinated Universal Time (UTC)。當您檢視檔案資訊時,會將它轉換為當地時間。若要到 UTC 與當地時間差異使用在 [日期及時間 中項目控制台中的 [時區] 索引標籤]。
SQL Server 2005 32 位元版本
檔案名稱檔案版本檔案大小日期時間平台
Microsoft.analysisservices.dll9.0.3175.01,217,9042007 年六月 14 日15: 05x86
Microsoft.sqlserver.maintenanceplantasks.dll9.0.3175.0296,3042007 年六月 14 日15: 05x86
Msmdlocal.dll9.0.3175.015,948,1442007 年六月 14 日15: 05x86
Mssqlsystemresource.ldf不適用524,2882007 年六月 14 日11: 22不適用
Mssqlsystemresource.mdf不適用40,173,5682007 年六月 14 日11: 22不適用
Odsole70.dll2005.90.3175.059,2482007 年六月 14 日15: 05x86
Rdistcom.dll2005.90.3175.0644,9762007 年六月 14 日15: 05x86
Replmerg.exe2005.90.3175.0320,8802007 年六月 14 日15: 05x86
Replrec.dll2005.90.3175.0784,7522007 年六月 14 日15: 05x86
Sqlaccess.dll2005.90.3175.0350,5762007 年六月 14 日15: 05x86
Sqlservr.exe2005.90.3175.029,193,0722007 年六月 14 日15: 05x86
Sqlwep.dll2005.90.3175.090,9922007 年六月 14 日15: 05x86
Sqsrvres.dll2005.90.3175.070,5122007 年六月 14 日15: 05x86
Sysdbupg.sql不適用510,6222007 年六月 13 日20: 46不適用
Xpstar90.dll2005.90.3175.0295,7922007 年六月 14 日15: 05x86
x x64 版本的 SQL Server 2005
檔案名稱檔案版本檔案大小日期時間平台
Microsoft.analysisservices.dll9.0.3175.01,217,9042007 年六月 14 日14: 05x86
Microsoft.sqlserver.maintenanceplantasks.dll9.0.3175.0296,3042007 年六月 14 日14: 05x86
Msmdlocal.dll9.0.3175.015,948,1442007 年六月 14 日14: 05x86
Mssqlsystemresource.ldf不適用524,2882007 年六月 14 日10: 22不適用
Mssqlsystemresource.mdf不適用40,173,5682007 年六月 14 日10: 22不適用
Odsole70.dll2005.90.3175.090,4802007 年六月 14 日16: 41x64
Rdistcom.dll2005.90.3175.0828,7842007 年六月 14 日16: 41x64
Replmerg.exe2005.90.3175.0417,6482007 年六月 14 日16: 41x64
Replrec.dll2005.90.3175.01,011,5682007 年六月 14 日16: 41x64
Sqlaccess.dll2005.90.3175.0357,7442007 年六月 14 日16: 41x86
Sqlservr.exe2005.90.3175.039,674,2242007 年六月 14 日16: 41x64
Sqlwep.dll2005.90.3175.090,9922007 年六月 14 日14: 05x86
Sqlwep.dll2005.90.3175.0123,7602007 年六月 14 日16: 41x64
Sqsrvres.dll2005.90.3175.083,3122007 年六月 14 日16: 41x64
Sysdbupg.sql不適用510,6222007 年六月 13 日19: 46不適用
Xpstar90.dll2005.90.3175.0546,6722007 年六月 14 日16: 41x64
SQL Server 2005 Itanium 架構版本
檔案名稱檔案版本檔案大小日期時間平台
Microsoft.analysisservices.dll9.0.3175.01,217,9042007 年六月 14 日15: 05x86
Microsoft.sqlserver.maintenanceplantasks.dll9.0.3175.0296,3042007 年六月 14 日15: 05x86
Msmdlocal.dll9.0.3175.049,904,4962007 年六月 14 日19: 56IA 64
Mssqlsystemresource.ldf不適用524,2882007 年六月 14 日11: 22不適用
Mssqlsystemresource.mdf不適用40,173,5682007 年六月 14 日11: 22不適用
Odsole70.dll2005.90.3175.0179,5682007 年六月 14 日19: 56IA 64
Rdistcom.dll2005.90.3175.01,885,5522007 年六月 14 日19: 56IA 64
Replmerg.exe2005.90.3175.0957,2962007 年六月 14 日19: 56IA 64
Replrec.dll2005.90.3175.02,145,1362007 年六月 14 日19: 56IA 64
Sqlaccess.dll2005.90.3175.0352,1122007 年六月 14 日19: 56x86
Sqlservr.exe2005.90.3175.072,530,8002007 年六月 14 日19: 56IA 64
Sqlwep.dll2005.90.3175.090,9922007 年六月 14 日15: 05x86
Sqlwep.dll2005.90.3175.0221,0402007 年六月 14 日19: 56IA 64
Sqsrvres.dll2005.90.3175.0147,3122007 年六月 14 日19: 56IA 64
Sysdbupg.sql不適用510,6222007 年六月 13 日20: 46不適用
Xpstar90.dll2005.90.3175.0957,2962007 年六月 14 日19: 56IA 64
其他可行方案
如果要解決這個問題,以手動方式放在 「 訂閱者的外部索引鍵的條件約束,在資料表上。
狀況說明
Microsoft 已確認<適用於>一節所列之 Microsoft 產品確實有此問題。
其他相關資訊

如果要重現問題的步驟

  1. 使用不是 dbo 結構描述的結構描述,以建立兩個資料表。
  2. 建立參考另一個資料表中的資料行的資料表上的外部索引鍵條件約束。

    附註當您建立外部索引鍵條件約束時,外部索引鍵條件約束會建立使用不是 dbo 結構描述的結構描述。
  3. 發佈這兩個資料表。

    附註當您將資料表發行確定會執行下列作業:
    • 指定主索引鍵條件約束和外部索引鍵條件約束是複製到 「 訂閱者。
    • 指定的發行項的 [目的地物件擁有者] 屬性是 dbo 使用者以外的擁有者。
  4. 初始化訂閱。
  5. 卸除發行者上的外部索引鍵條件約束。
  6. 執行合併代理程式來同步處理發行者和訂閱者之間的資料。
参考
如 SQL Server 更新命名的結構描述的更多有關,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
822499Microsoft SQL Server 軟體更新套件的新命名結構描述
如需有關軟體更新術語的詳細資訊,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
824684用來描述 Microsoft 軟體更新標準術語的說明

警告:本文為自動翻譯

內容

文章識別碼:938825 - 最後檢閱時間:11/20/2007 17:47:05 - 修訂: 1.4

Microsoft SQL Server 2005 Express Edition, Microsoft SQL Server 2005 Express Edition with Advanced Services, Microsoft SQL Server 2005 Workgroup Edition, Microsoft SQL Server 2005 Standard Edition, Microsoft SQL Server 2005 Developer Edition, Microsoft SQL Server 2005 Enterprise Edition, Microsoft SQL Server 2005 Standard X64 Edition, Microsoft SQL Server 2005 Enterprise X64 Edition, Microsoft SQL Server 2005 Standard Edition for Itanium Based Systems, Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems

  • kbmt kbautohotfix kbhotfixserver kbexpertiseadvanced kbqfe kbfix KB938825 KbMtzh
意見反應