[FIX] SQL Server 2005 のマージ レプリケーションでサブスクライバーのテーブルにパブリッシャーのテーブルで削除する、外部キー制約は削除されません。

文書翻訳 文書翻訳
文書番号: 938825 - 対象製品
# BUG: 50001169 (SQL 修正プログラム)

マイクロソフトでは Microsoft SQL Server 2005 の修正プログラム、1 つのダウンロード ファイルとして配布します。 修正プログラムは累積的なあるため各新しいリリースすべての修正プログラムおよびが含まれています、以前の SQL Server 2005 に同梱されたすべてのセキュリティ修正プログラム リリースを修正します。
すべて展開する | すべて折りたたむ

目次

概要

ここでは、次についてこの修正プログラムのリリースについて説明します。
  • 修正プログラム パッケージで修正される問題
  • 修正プログラム パッケージのインストールの前提条件
  • この修正プログラム パッケージのインストール後にコンピュータを再起動する必要があるかどうか
  • この修正プログラム パッケージが他の修正プログラム パッケージによって置き換えられるかどうか
  • レジストリの変更が必要かどうか
  • 修正プログラム パッケージでに含まれているファイル

現象

Microsoft SQL Server 2005、マージ レプリケーションでテーブルに外部キー制約を削除する、パブリッシャーで。 後、パブリッシャーとサブスクライバー間でデータを同期するレプリケーション マージ エージェントでは、サブスクライバーのテーブルに外部キー制約は削除できません。

この問題は、関連するテーブル、パブリッシャーとサブスクライバーの dbo スキーマに属さない場合に発生します。

原因

この問題は、不適切なクエリが、レプリケーション マージ エージェントはサブスクライバーで実行されるために発生します。 OBJECT_ID 関数はレプリケーション マージ エージェント、クエリの実行時に NULL を返します。 IF EXISTS ステートメントは、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')

解決方法

情報を更新します。

この修正プログラムは累積的な更新プログラム パッケージ (ビルド 3175) 2 に SQL Server 2005 Service Pack 2 (SP2) は含まれます。

この資料に記載されている問題を解決するには、次の手順に従います。
  1. SQL Server 2005 SP2 をインストールします。
  2. SQL Server 2005 SP2 用の累積的な更新プログラム パッケージ (ビルド 3175) 2 をインストールします。
についてには、記事の「サポート技術情報」(Microsoft Knowledge Base) を表示する次の資料番号をクリックしてします。
913089SQL Server 2005 の最新の Service Pack の入手方法
936305SQL Server 2005 Service Pack 2 用の累積的な更新プログラム パッケージ 2 には

修正プログラムについて

サポートされている修正プログラムが Microsoft から提供されています。 ただし、ことを目的としたこの修正プログラムものですこの資料に記載されている問題のみを修正します。 この修正プログラムのみシステムに適用この特定の問題が発生しています。 この修正プログラム テストを受ける可能性があります。 そのため場合この問題で深刻な影響を受けていないお勧めしますこの修正プログラムを含む、次回ソフトウェアの更新されるまで待つことです。

修正プログラムをダウンロードできる場合はこの資料の先頭に「修正プログラムのダウンロード」セクションです。 このセクションが表示されていない場合、は、マイクロソフト カスタマーサービス & サポート修正プログラムを入手するを問い合わせてください。

メモ 追加問題が発生する場合は、個別のサービス要求を作成した任意のトラブルシューティングが必要な場合。 通常のサポート料金が追加の質問およびこの特定の修正プログラムの対象とならない問題について適用されます。 一覧については、完了マイクロソフト カスタマーサービス & サポートの電話番号のまたは個別のサービス要求を作成する、次のマイクロソフト Web サイトを参照してください。
http://support.microsoft.com/contactus/?ws=support
メモ 「修正プログラムのダウンロード」フォームには、修正プログラムが利用する言語が表示されます。 お使いの言語が表示されない場合、修正プログラムがその言語に対応しないのでは。

前提条件

SQL Server 2005 SP2 インストールこの修正プログラムを適用する必要があります。

再起動について

コンピューターを再起動するがありません。

修正プログラム置き換えに関する情報

この修正プログラムは、他の修正プログラムによって置き換えられるありません。

レジストリについて

レジストリを変更するがありません。

ファイル情報

この修正プログラムには、この資料に記載されている問題を修正するために必要なファイルのみが含まれています。 この修正プログラムには、製品を最新のビルドに更新するために必要なファイルがすべて含まれているとは限りません。

英語版のこの修正プログラムにファイルの属性 (またはそれ以降のファイル属性) 次の表は、されている可能性もします。 日付およびこれらのファイルの時間で世界協定時刻 (UTC) と記載します。 各ファイルの日付および時刻は、世界協定時刻 (UTC) で示されています。 UTC と現地時刻の差を検索するには、コントロール パネルの [ 日付と時刻 タイム ゾーン タブを使用します。
SQL Server 2005、32 ビット版
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間プラットフォーム
Microsoft.analysisservices.dll9.0.3175.01,217,9042007 年 6 月 14 日15: 05x86
Microsoft.sqlserver.maintenanceplantasks.dll9.0.3175.0296,3042007 年 6 月 14 日15: 05x86
Msmdlocal.dll9.0.3175.015,948,1442007 年 6 月 14 日15: 05x86
Mssqlsystemresource.ldf該当なし524,2882007 年 6 月 14 日11: 22該当なし
Mssqlsystemresource.mdf該当なし40,173,5682007 年 6 月 14 日11: 22該当なし
Odsole70.dll2005.90.3175.059,2482007 年 6 月 14 日15: 05x86
Rdistcom.dll2005.90.3175.0644,9762007 年 6 月 14 日15: 05x86
Replmerg.exe2005.90.3175.0320,8802007 年 6 月 14 日15: 05x86
Replrec.dll2005.90.3175.0784,7522007 年 6 月 14 日15: 05x86
Sqlaccess.dll2005.90.3175.0350,5762007 年 6 月 14 日15: 05x86
Sqlservr.exe2005.90.3175.029,193,0722007 年 6 月 14 日15: 05x86
Sqlwep.dll2005.90.3175.090,9922007 年 6 月 14 日15: 05x86
Sqsrvres.dll2005.90.3175.070,5122007 年 6 月 14 日15: 05x86
Sysdbupg.sql該当なし510,6222007 年 6 月 13 日20: 46該当なし
Xpstar90.dll2005.90.3175.0295,7922007 年 6 月 14 日15: 05x86
SQL Server 2005 の x64 ベース バージョン x、
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間プラットフォーム
Microsoft.analysisservices.dll9.0.3175.01,217,9042007 年 6 月 14 日14: 05x86
Microsoft.sqlserver.maintenanceplantasks.dll9.0.3175.0296,3042007 年 6 月 14 日14: 05x86
Msmdlocal.dll9.0.3175.015,948,1442007 年 6 月 14 日14: 05x86
Mssqlsystemresource.ldf該当なし524,2882007 年 6 月 14 日10: 22該当なし
Mssqlsystemresource.mdf該当なし40,173,5682007 年 6 月 14 日10: 22該当なし
Odsole70.dll2005.90.3175.090,4802007 年 6 月 14 日16: 41x64
Rdistcom.dll2005.90.3175.0828,7842007 年 6 月 14 日16: 41x64
Replmerg.exe2005.90.3175.0417,6482007 年 6 月 14 日16: 41x64
Replrec.dll2005.90.3175.01,011,5682007 年 6 月 14 日16: 41x64
Sqlaccess.dll2005.90.3175.0357,7442007 年 6 月 14 日16: 41x86
Sqlservr.exe2005.90.3175.039,674,2242007 年 6 月 14 日16: 41x64
Sqlwep.dll2005.90.3175.090,9922007 年 6 月 14 日14: 05x86
Sqlwep.dll2005.90.3175.0123,7602007 年 6 月 14 日16: 41x64
Sqsrvres.dll2005.90.3175.083,3122007 年 6 月 14 日16: 41x64
Sysdbupg.sql該当なし510,6222007 年 6 月 13 日19: 46該当なし
Xpstar90.dll2005.90.3175.0546,6722007 年 6 月 14 日16: 41x64
SQL Server 2005 を Itanium アーキテクチャのバージョン
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間プラットフォーム
Microsoft.analysisservices.dll9.0.3175.01,217,9042007 年 6 月 14 日15: 05x86
Microsoft.sqlserver.maintenanceplantasks.dll9.0.3175.0296,3042007 年 6 月 14 日15: 05x86
Msmdlocal.dll9.0.3175.049,904,4962007 年 6 月 14 日19: 5664
Mssqlsystemresource.ldf該当なし524,2882007 年 6 月 14 日11: 22該当なし
Mssqlsystemresource.mdf該当なし40,173,5682007 年 6 月 14 日11: 22該当なし
Odsole70.dll2005.90.3175.0179,5682007 年 6 月 14 日19: 5664
Rdistcom.dll2005.90.3175.01,885,5522007 年 6 月 14 日19: 5664
Replmerg.exe2005.90.3175.0957,2962007 年 6 月 14 日19: 5664
Replrec.dll2005.90.3175.02,145,1362007 年 6 月 14 日19: 5664
Sqlaccess.dll2005.90.3175.0352,1122007 年 6 月 14 日19: 56x86
Sqlservr.exe2005.90.3175.072,530,8002007 年 6 月 14 日19: 5664
Sqlwep.dll2005.90.3175.090,9922007 年 6 月 14 日15: 05x86
Sqlwep.dll2005.90.3175.0221,0402007 年 6 月 14 日19: 5664
Sqsrvres.dll2005.90.3175.0147,3122007 年 6 月 14 日19: 5664
Sysdbupg.sql該当なし510,6222007 年 6 月 13 日20: 46該当なし
Xpstar90.dll2005.90.3175.0957,2962007 年 6 月 14 日19: 5664

回避策

この問題を回避するには、サブスクライバーでテーブルに外部キー制約をドロップ手動で。

状況

マイクロソフトとして認識していますこの問題を記載されているいるマイクロソフト製品の問題。

詳細

この問題を再現する手順

  1. 2 つテーブルは、dbo スキーマではないスキーマを使用して作成します。
  2. 別のテーブルの列を参照するテーブルに外部キー制約を作成します。

    メモ 外部キー制約を作成すると、外部キー制約が、dbo スキーマではないスキーマを使用して作成されます。
  3. 両方のテーブルを発行します。

    メモ テーブルを発行する場合は、次の操作を実行することを確認ください。
    • 指定する、主キー制約、外部キー制約が、サブスクライバーにコピーします。
    • アーティクルの コピー先オブジェクトの所有者 プロパティが、所有者の dbo ユーザー以外はことを指定します。
  4. サブスクリプションを初期化します。
  5. パブリッシャーで外部キー制約を削除します。
  6. パブリッシャーとサブスクライバー間でデータを同期するには、マージ エージェントを実行します。

関連情報

SQL Server の更新プログラムの名前付けスキーマの詳細についてはをクリックして以下「サポート技術情報」(Microsoft Knowledge Base) 資料を参照。
822499Microsoft SQL Server ソフトウェア更新プログラム パッケージの新しい名前付けスキーマ
ソフトウェア更新の用語についてについては、資料の「サポート技術情報」(Microsoft Knowledge Base) を表示する次の資料番号をクリック。
824684マイクロソフトのソフトウェアの更新で使用される一般的な用語の説明

プロパティ

文書番号: 938825 - 最終更新日: 2007年11月20日 - リビジョン: 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
キーワード:?
kbfix kbqfe kbexpertiseadvanced kbhotfixserver kbautohotfix kbmt KB938825 KbMtja
機械翻訳の免責
重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。
英語版 KB:938825
Microsoft Knowledge Base の免責: Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。

フィードバック

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com