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

重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。

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).NameEnd Sub					
  2. 上記プロジェクトを実行すると、不適切な列数が表示されます。 また表示エラー オブジェクトが開いている"Visual Basic ウォッチ] ウィンドウで、レコードセットのフィールドの数を観察する場合。 ここでは、"Debug.Print rs.Fields.Count"の行が [イミディエイト] ウィンドウに結果を印刷されません。

警告: この資料は、自動翻訳されています

プロパティ

文書番号:283842 - 最終更新日: 01/05/2015 12:56:30 - リビジョン: 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
  • kbnosurvey kbarchive kbbug kbfix kboracle kbprovider kbqfe kbmdac260sp2fix kbmdac250sp3fix kbhotfixserver kbmt KB283842 KbMtja
フィードバック