FIX: 使用 Jet 提供者,以查詢連結的伺服器文字檔從 SQL Server 可能會非常慢的速度

重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。

290415
本文已封存。本文係以「現狀」提供且不會再更新。
Bug #: 236329 (SHILOH_BUGS)
Bug #: 236615 (SHILOH_BUGS)
Bug #: 352865 (SHILOH_BUGS)
徵狀
使用 Jet OLEDB 提供者 (OLE DB 提供者的 Jet [文字 IISAM]) 從 SQL Server 連結伺服器存取文字檔案時查詢可能要花很長的時間。只有當大量文字檔案中的資料行時,就會發生緩慢的查詢效能。
發生的原因
Jet OLEDB 提供者查詢 Jet 屬性管理員 為每個資料行以屬性的屬性為基礎。Jet 4.0 服務封包 5 (SP5) 以開始查詢在大幅加快查詢的大量模式執行。
解決方案
如果要解決這個問題,取得最新的 Service Pack,Microsoft SQL Server 2000。如需詳細資訊按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
290211INF: 如何取得最新的 SQL Server 2000 Service Pack
已經在最新版本的 Jet Service Pack 中修正這個問題。如需有關如何取得最新版本的 Jet 4.0 資料庫引擎的詳細資訊,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
239114如何: 取得最新的 Service Pack,為 Microsoft Jet 4.0 資料庫引擎
其他可行方案
如果要解決此問題,使用不同的提供者來查詢 SQL Server 從文字檔案。
狀況說明
Microsoft 已確認這是在 Microsoft SQL Server 2000 中的問題。這個問題已經先在 SQL Server 2000 Service Pack 1 中獲得修正。
其他相關資訊
電腦停止回應 (擱置),當 SQL Server 呼叫 IDBSchemaRowset::GetRowset(DBSCHEMA_COLUMNS)。

重製行為的步驟

若要重現這個問題,執行如下的程式碼範例。

注意: 此範例假設 C:\MyDir\TextFile.txt 檔案有 255 的資料行。
exec sp_addlinkedserver @server = 'My Documents', @provider = 'Microsoft.Jet.OLEDB.4.0', @srvproduct = 'OLE DB Provider for Jet (Text IISAM)', @datasrc = 'c:\MyDir\', @provstr = 'Text'goexec sp_addlinkedsrvlogin 'My Documents', false, NULL, 'admin'goSELECT * FROM [My Documents]...[TextFile#txt] goexec sp_droplinkedsrvlogin 'My Documents', nullexec sp_dropserver 'My Documents'go				
IDBSchemaRowset::GetRowset(DBSCHEMA_COLUMNS) 擱置效能存取

Warning: This article has been translated automatically

內容

文章識別碼:290415 - 最後檢閱時間:01/16/2015 21:47:20 - 修訂: 4.2

  • Microsoft SQL Server 2000 Standard Edition
  • kbnosurvey kbarchive kbmt kbbug kbfix kbsqlserv2000sp1fix KB290415 KbMtzh
意見反應