[FIX IN と UNION 句は無効な列数を生成します。

文書翻訳 文書翻訳
文書番号: 283842 - 対象製品
すべて展開する | すべて折りたたむ

現象

Microsoft OLE DB プロバイダー Oracle (MSDAORA) で IN と UNION 句の両方を含む SQL ステートメントの実行が間違った列数を格納する ActiveX データ オブジェクト (ADO) レコードセット オブジェクトを生成可能性があります。

この問題は、ADO では、クライアント側カーソル (つまり、 CursorLocation プロパティが adUseClient に設定されている) を使用して場合に発生しますが、サーバー側カーソルを使用する場合は正常に動作します。

解決方法

この問題を解決するには、Microsoft MDAC 2. 5 の最新のサービス パックの入手します。 関連情報を参照するには、以下の「サポート技術情報」 (Microsoft Knowledge Base) をクリックしてください:
293312[INFO] 最新の MDAC 2.5 Service Pack の入手方法
この問題を解決するには、Microsoft Data Access Components 2.6 の最新の Service Pack を入手します。 関連情報を参照するには、以下の「サポート技術情報」 (Microsoft Knowledge Base) をクリックしてください:
300635情報: 最新の MDAC 2. 6 を取得するサービス パック

修正プログラム

ただし、これより新しい修正ファイルがリリースされている可能性もあります:
   Version       Size      File name     Platform
   -------------------------------------------------------
   2.53.6007.0   209,168   Msdaora.dll   x86
				

回避策

問題は、サーバー側カーソルを使用する場合は発生しません、 CursorLocation プロパティは adUseServer に設定します。

状況

マイクロソフトとして認識していますこの問題をこの資料の冒頭に記載されているマイクロソフト製品の問題。 この問題は、まず Microsoft データ アクセス コンポーネントの 2. 6 Service Pack 2、MDAC 2. 5 SP3、および MDAC 2. 7 で修正されました。

詳細

動作を再現する手順

  1. 新しい Visual Basic プロジェクトで、次のコードを追加し、ActiveX データ オブジェクトの 2. 5 のライブラリへのプロジェクト参照の設定:
    Private Sub Command1_Click()
    
        Dim cn As New ADODB.Connection
        Dim rs As New ADODB.Recordset
        cn.Open "Provider=MSDAORA;Data Source=your_oracle_server;User ID=your_user_name;Password=your_password"
        On Error Resume Next
        cn.Execute "Drop table oratest"
        cn.Execute "CREATE TABLE ORATEST(Col1 VARCHAR2(10) NULL," & _
                   "Col2 VARCHAR2(10) NULL)"
        cn.Execute "insert into oratest values(7,7)"
        cn.Execute " insert into oratest values(6,6)"
        cn.Execute "Drop table DUAL"
        cn.Execute "CREATE TABLE DUAL(C11 VARCHAR2(10) NULL," & _
                   "C12 VARCHAR2(10) NULL)"
        cn.Execute "insert into dual values(6,7)"
        rs.CursorLocation = adUseClient
        rs.Open "select col1, col2 from oratest where col1 in (Select C11 from dual union select C12 from dual)", _
                cn, adOpenStatic,adLockBatchOptimistic
        
        Debug.Print rs.Fields.Count      '<--- incorrect column count       
        Debug.Print rs.Fields(0).Name
        Debug.Print rs.Fields(1).Name
    End Sub
    					
  2. 上記プロジェクトを実行すると、不適切な列数が表示されます。 また表示エラー オブジェクトが開いている"Visual Basic ウォッチ] ウィンドウで、レコードセットのフィールドの数を観察する場合。 ここでは、"Debug.Print rs.Fields.Count"の行が [イミディエイト] ウィンドウに結果を印刷されません。

プロパティ

文書番号: 283842 - 最終更新日: 2006年4月7日 - リビジョン: 6.1
この資料は以下の製品について記述したものです。
  • Microsoft OLE DB Provider for Oracle Server 1.0
  • Microsoft OLE DB Provider for Oracle Server 1.0
  • Microsoft Data Access Components 2.5
  • Microsoft Data Access Components 2.5 Service Pack 1
  • Microsoft Data Access Components 2.6
キーワード:?
kbbug kbfix kboracle kbprovider kbqfe kbmdac260sp2fix kbmdac250sp3fix kbhotfixserver kbmt KB283842 KbMtja
機械翻訳の免責
重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。
英語版 KB:283842
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