FIX: 連線遺漏使用參數化中 ADO 命令

文章翻譯 文章翻譯
文章編號: 247757 - 檢視此文章適用的產品。
本文已封存。本文係以「現狀」提供且不會再更新。
全部展開 | 全部摺疊

在此頁中

徵狀

使用 Windows 基礎類別的 Java WFC ADO 和並開啟資料錄集使用參數化的命令物件,正常關閉的連接無法正確地共用與回收時, 導致遺漏的連線。 如果要解決這個問題,呼叫 System.gc() 之後關閉 ADO 連接 Java COM 物件中。在正常情況下,您不需要呼叫 System.gc() ADO 連線關閉以釋放連線後。

解決方案

在最新的 Service Pack 的 Windows 2000 和 MDAC 2.5 中解決此問題。
  • 如果要解決這個問題,取得最新的 Service Pack 為 Windows 2000。如需詳細資訊按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
    260910如何取得最新的 Windows 2000 Service Pack
  • 如果要解決這個問題,取得最新的 Service Pack 的 Microsoft 資料存取元件 2.5。如需詳細資訊按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
    293312資訊: 如何取得最新的 MDAC 2.5 Service Pack
此修正程式的英文版應該具有下列檔案屬性或更新版本:
File name       Date        Size      Version      
-----------------------------------------------------
Msado15.dll     1/26/2000   329KB     2.12.4926.0
				

狀況說明

Microsoft 已確認這是 Microsoft 資料存取 Objects2.1 SP2 和 2.5 中的問題。這個問題,首先已經在 Microsoft 資料存取元件 2.5 Service Pack 2 和 Microsoft Windows 2000 Service Pack 2 中獲得修正。

其他相關資訊

當下列條件全部存在時,就會發生共用問題這個連線/活動:
  1. 安裝 Microsoft 資料存取物件 2.1 SP2。
  2. 使用參數化的 ADO 命令物件。
  3. Java COM 物件被裝載在 MTS 或 COM +。
  4. Java COM 物件會建立離線式資料錄集。

重製行為的步驟

  1. 建立名為 Visual J++ 6.0 使用下列程式碼的 ConnLoss Java COM 物件專案:
    import com.ms.wfc.data.*;
    
    public class ConnLoss
    {
      // Modify this connection string to point to a running SQL Server.
      private static String m_connect = 
        "Provider=SQLOLEDB;Server=(Local);Database=Pubs;UID=sa;PWD=;";
      public com.ms.wfc.data.adodb._Recordset 
        FindAuthorsLastName( String au_id, boolean fCallGC )
      {
        Connection conn = null;
        Command cmd   = null;
        Recordset rs  = null;
        try
        {     
          // Open connection to SQL Server.
          conn = new Connection();
          conn.setCursorLocation( AdoEnums.CursorLocation.CLIENT );
          conn.open( m_connect );
          
          // Prepare command object.
          cmd = new Command();
          cmd.setActiveConnection( conn );
          
          cmd.setCommandText( "select au_lname from authors where au_id=?" );
        
          cmd.getParameters().append( 
            cmd.createParameter( "au_id", 
                       AdoEnums.DataType.VARCHAR,
                       AdoEnums.ParameterDirection.INPUT,
                       20, au_id ) );
          
          // Execute command.
          rs = cmd.execute();
          
          // Disconnect recordset and close connection.
          rs.setActiveConnection( (Connection) null );
          conn.close();
          
          // Call gc if requested.
          if (fCallGC) System.gc();
          
          // Return disconnected recordset.
          return (com.ms.wfc.data.adodb._Recordset) rs.getDataSource();
          
        }
        catch( AdoException adoEX )
        {
          // Log errors here.
        }
        return null;
      }
    }
    					
  2. 將 Java COM 物件加入至 MTS 或 COM + 套件。
  3. 為應用程式 VBA 程式碼呼叫 Java COM 物件與下列 Microsoft VB:
    Sub TestConnLoss()
    Dim objCL As Object
    Dim i As Long
    Dim rs As ADODB.recordset
      set objCL = CreateObject("ConnLoss.ConnLoss")
      For i = 1 To 100
        Set rs = objCL.FindAuthorsLastName("756-30-7391", False)
        Debug.Print rs.Fields("au_lname").Value
        rs.Close
        Set rs = Nothing    
      Next i    
    End Sub
    					
  4. SQL Server 7.0 所在機器上執行 Windows NT 效能監視器,並監視 SQL Server: 一般統計資料 的效能計數器] 下的使用者連線。
  5. 執行 VBA 用戶端程式碼。 這個時候 100 個使用者連接所產生程式碼的 Windows NT 效能監視器指出 OLE DB 工作階段共用無法正常運作的 Java COM 物件所用的 SQL OLE DB 提供者報告了。

  6. 變更為 TrueFindAuthorsLastName 第二個參數,才能啟動 System.gc() 程式碼。
  7. 停止並重新啟動 MTS 或 COM + 封裝。
  8. 第二次執行 VBA 用戶端程式碼。
此時只有幾個使用者連線是由程式碼指出的 OLE DB 工作階段共用運作正常的 System.gc() 呼叫時,Java COM 物件所用的 SQL OLE DB 提供者所產生。

注意: 呼叫 System.gc() 大幅影響 Java COM 物件的效能,所以呼叫 System.gc() 一般來說應該避免使用當效能是一項考量時。 例如商務物件可以撰寫成只呼叫的 System.gc() 每隔 10 或 100 方法呼叫來減少每個方法的呼叫 System.gc() 的效能影響。 此外,參數化的命令物件的使用可能會避免硬式編碼參數值成 SQL 字串] 和 [不使用參數語彙基元 (Token),為在上述範例中 ; 這 circumvents 同樣的問題。

屬性

文章編號: 247757 - 上次校閱: 2014年2月23日 - 版次: 3.0
這篇文章中的資訊適用於:
  • Microsoft Data Access Components 2.1 Service Pack 2
  • Microsoft Data Access Components 2.5
  • Microsoft Visual J++ 6.0 Standard Edition
關鍵字:?
kbnosurvey kbarchive kbmt kbqfe kbhotfixserver kbbug kbfix kbmdac250sp2fix KB247757 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:247757
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