FIX: IN 和 UNION 子句產生不正確的資料行計數

文章翻譯 文章翻譯
文章編號: 283842 - 檢視此文章適用的產品。
全部展開 | 全部摺疊

徵狀

與 Microsoft OLE DB 提供者對於 Oracle (MSDAORA),包含 IN 和 UNION 子句的 SQL 陳述式執行可能會產生 ActiveX 資料物件 (ADO) 資料錄集 物件,其中包含資料行數目不正確。

當使用 ADO 用戶端資料指標 (亦即 [CursorLocation] 屬性設定為 [adUseClient) 時,就會發生這個問題,但在使用伺服器端資料指標的運作正常。

解決方案

如果要解決這個問題,取得最新的 Service Pack 的 Microsoft MDAC 2.5。如需詳細資訊按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
293312資訊: 如何取得最新的 MDAC 2.5 Service Pack
如果要解決這個問題,取得最新的 Service Pack 的 Microsoft 資料存取元件 2.6。如需詳細資訊按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
300635資訊: 如何取得最新的 MDAC 2.6 Service Pack

Hotfix

此修正程式的英文版應該具有下列檔案屬性或更新版本:
   Version       Size      File name     Platform
   -------------------------------------------------------
   2.53.6007.0   209,168   Msdaora.dll   x86
				

其他可行方案

沒有發生此問題,如果您使用伺服器端資料指標 ; CursorLocation 屬性設為 [adUseServer

狀況說明

Microsoft 已確認這是在本文開頭所列之 Microsoft 產品中的問題。 這個問題,首先已經在 Microsoft 資料存取元件 2.6 Service Pack 2、 MDAC 2.5 SP3 和 MDAC 2.7 中獲得修正。

其他相關資訊

重製行為的步驟

  1. 在新的 Visual Basic 專案中加入下列程式碼,並設定到 Microsoft 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
關鍵字:?
kbmt kbqfe kbhotfixserver kbmdac250sp3fix kbbug kbfix kbmdac260sp2fix kboracle kbprovider KB283842 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:283842
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。

提供意見

 

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