FIX: SQLOLEDB 提供者不正確地離開交易開啟

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

在此頁中

徵狀

執行某些涉及明確交易和應用程式不當使用 「 SQLOLEDB 提供者 」 中的參數的指令序列會留下未認可的交易開啟。這會造成嚴重的封鎖和其他問題。

發生的原因

雖然 SET 選項 'implicit_transactions' 設定為 OFF,SQLOLEDB 提供者開啟隱含的交易。

解決方案

MDAC 2.6

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

Hotfix

重要: Microsoft 資料存取元件版本 2.6 套用這個 Hotfix 之前,必須先安裝。

此修正程式的英文版應該具有下列檔案屬性或更新版本:
   Date       Time     Version     Size      File name      Platform
   -----------------------------------------------------------------
   11/22/00   8:43pm   8.00.0225   491,584   Sqloledb.dll   Intel
   11/22/00   8:43pm   8.00.0225    61,440   Sqloledb.rll   Intel
				
注意: 由於檔案相依性最新版 Hotfix 或包含上述檔案的功能也可能會包含其他檔案。

其他可行方案

如果要解決這個問題,執行下列步驟之一:
  • 使用 ODBC,而不是 [SQLOLEDB OLEDB 提供者提供者。

    -或者-
  • 將會建立問題的程式碼周圍的額外交易。

狀況說明

Microsoft 已確認這是 Microsoft OLE DB 提供者包含在 2.1、 2.5 和 2.6 的 Microsoft 資料存取元件 (MDAC) 版本的 SQL Server 中的問題。

MDAC 2.6

這個問題,首先已經在 Microsoft 資料存取元件 2.6 Service Pack 1 中獲得修正。


MDAC 2.5

這個問題已經先在 Sqlredis.exe 隨附於 Microsoft SQL Server 7.0 服務套件 4 的版本中獲得修正。

其他相關資訊

透過追蹤應用程式,您在中所見 SQL Server Profiler SQLOLEDB 提供者會傳送到 SQL Server 下列陳述式:
SET FMTONLY ON select ... SET FMTONLY OFF
set implicit_transactions off SET NO_BROWSETABLE OFF
				
這個原因 'implicit_transaction' 已經被開啟。

而 ODBC 與 SQL Server 驅動程式使用 OLEDB 提供者時, 完全相同的 Visual Basic/ADO 程式碼會將下列陳述式傳送到 SQL Server:
set implicit_transactions off SET NO_BROWSETABLE OFF
SET FMTONLY ON select  ... SET FMTONLY OFF
				
因此 FMTONLY SELECT 開啟 SQLOLEDB 使用隱含的交易。 不過,因為應用程式永遠不會開啟此交易,應用程式將正常永遠不會關閉它。此交易將只會關閉在下一個外顯交易時。

屬性

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