FIX、クエリに対してリンク サーバーを実行すると、エラー メッセージ、SQL Server 2005 で作成:「ステートメントを準備できませんでしたいないする」および"列のプレフィックス '<column_prefix_name>' をテーブル名またはエイリアス名をクエリで使用されると一致しません"</column_prefix_name>

文書翻訳 文書翻訳
文書番号: 936223
# をバグ: 50001186 (SQL 修正プログラム)
すべて展開する | すべて折りたたむ

目次

現象

次のシナリオを検討してください。Microsoft SQL Server 2005 では、SQL ネイティブ クライアント OLE DB プロバイダー (SQLNCLI) を使用してリンク サーバーを作成します。リンク サーバーは、Microsoft SQL Server 2000 がインストールされているサーバーにリンクされています。このシナリオでは、リンク サーバーに対してクエリを実行すると、次のエラー メッセージが表示されます。
エラー メッセージ 1
メッセージ 8180、レベル 16、状態 1、行 1
ステートメントを準備できませんでした。
エラー メッセージ 2
Msg 107、レベル 16、状態 2、行 1
列のプレフィックス '<column_prefix_name></column_prefix_name>' をテーブル名またはエイリアス名をクエリで使用されると一致しません。


メモ この問題は、SQL Server 2008 でも発生します。SQL Server 2008 SQL Server 2000年サーバーに接続するときにこの問題が発生する場合は、トレース フラグ 4112 をこの問題を解決するを有効にする必要があります。詳細については、「関連情報」セクションを参照してください。

原因

この問題は、SQL Server 2005 のリモート クエリが、実行プランを生成するために発生します。SQL Server 2005 に対して必要なデータを取得するのには、SQL Server 2000年リモート クエリを実行する必要があります。SQL Server 2000年リモート クエリを処理できません。したがって、エラー 107 SQL Server 2000 のでに発生します。その後、エラー 107 は、SQL Server 2005 に戻す伝達されます。したがって、SQL Server 2005 では、107 をエラーが発生してエラー 8180 は SQL Server 2005 で発生します。

解決方法

累積的な更新プログラムの情報

この問題に対する修正は累積的な更新プログラム 2 に初めてリリースされました。この累積的な更新プログラム パッケージを SQL Server 2005 Service Pack 2 を入手する方法の詳細については、Knowledge Base の資料を参照するのには、次の資料番号をクリックしてください。
936305 SQL Server 2005 Service Pack 2 用の累積的な更新プログラム パッケージ 2
メモ ビルドは累積的であるため、新しい修正プログラム リリースすべての修正プログラムが含まれているし、以前の SQL Server 2005 に含まれていたすべてのセキュリティ修正プログラム リリースを修正します。マイクロソフトはこの修正プログラムを含む最新の修正プログラム リリースを適用を検討することをお勧めします。詳細については、Knowledge Base の資料を参照するのには、次の資料番号をクリックしてください。
937137 SQL Server 2005 Service Pack 2 のリリース以降後にリリースされた、SQL Server 2005 のビルドします。
特定の SQL Server のサービス パックの Microsoft SQL Server 2005年の修正プログラムが作成されます。SQL Server 2005 Service Pack 2 のインストールに SQL Server 2005 Service Pack 2 修正プログラムを適用する必要があります。既定では、SQL Server サービス パックで提供されている修正プログラム SQL Server の次の service pack に含まれてです。

回避策

この問題を回避するには、Microsoft OLE DB プロバイダー用 ODBC を使用して、SQL Server 2000年に対してリンク サーバーを作成します。

状況

マイクロソフトでは、この「対象」に記載されているマイクロソフト製品の問題として認識しています。

詳細

SQL Server 2008年、SQL Server 2005 SP2 の累積的な更新プログラム パッケージ (ビルド 3175) 両方紹介トレース フラグ 4112。SQL Server 2005 SP2 の累積的な更新プログラム パッケージ (ビルド 3175) を適用した後、トレース フラグ 4112 をこの問題を解決するを有効にする必要があります。SQL Server 2005 でトレース フラグを有効にする方法の詳細については、次のマイクロソフト開発ネットワーク (MSDN) Web サイトの「解説」を参照してください。
http://msdn2.microsoft.com/en-us/library/ms188396.aspx

問題の再現手順

  1. SQL Server Management Studio を開始し、SQL Server 2005 のインスタンスに接続します。
  2. 新しいクエリを作成し、次のステートメントを実行します。
    EXEC sp_addlinkedserver
    @server = '<LinkedServerName>', 
    @provider = 'SQLNCLI', 
    @srvproduct = '', 
    @datasrc = '<InstanceName>', 
    @catalog = '<DatabaseName>' 
    
    exec sp_serveroption
    @server = '<LinkedServerName>' 
    ,@optname = 'RPC' 
    ,@optvalue = 'TRUE'
    exec sp_serveroption
    @server = '<LinkedServerName>' 
    ,@optname = 'RPC OUT' 
    ,@optvalue = 'TRUE'
    
    
    DECLARE @supervisorID varchar(40)
    set @supervisorID = 'Volume Discount'
    
    SELECT DISTINCT J.STOR_ID
    FROM   [<LinkedServerName>].[<DatabaseName>].DBO.DISCOUNTS J
    WHERE  J.DISCOUNTTYPE = @supervisorID
           AND J.DISCOUNT = (SELECT MAX(B.DISCOUNT)
                             FROM   [<LinkedServerName>].<DatabaseName>.DBO.DISCOUNTS B
                             WHERE  B.DISCOUNTTYPE = J.DISCOUNTTYPE)
    
    GO
    
    メモ
    • <linkedservername></linkedservername> リンク サーバーの名前のプレース ホルダーです。
    • <instancename></instancename> リンク サーバーのインスタンス名のプレース ホルダーです。
    • <databasename></databasename> データベースの名前のプレース ホルダーです。
これらのステートメントを実行すると、「現象」に記載されているエラー メッセージが表示されます。

プロパティ

文書番号: 936223 - 最終更新日: 2011年8月9日 - リビジョン: 6.0
キーワード:?
kbfix kbqfe kbpubtypekc kbexpertiseadvanced kbsql2005engine kbmt KB936223 KbMtja
機械翻訳の免責
重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。
英語版 KB:936223
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