FIX: 當您在 SQL Server 2005 中執行複雜的查詢時,查詢效能變慢如果查詢的執行計劃包含半聯結運算子

文章翻譯 文章翻譯
文章編號: 940128 - 檢視此文章適用的產品。
Bug #: 50001440 (SQL Hotfix)
注意事項
Microsoft 為一個可下載檔案散佈 Microsoft SQL Server 2005 的修正程式。因為修正程式是累積,每個新版本包含所有 Hotfix 及先前的 SQL Server 2005 隨附所有安全性修正程式都修正發行。
全部展開 | 全部摺疊

在此頁中

結論

本文將告訴您下列關於此 Hotfix 版本:
  • Hotfix 套件所修正的問題
  • 安裝 Hotfix 套件的先決條件
  • 是否您必須重新啟動電腦安裝 Hotfix 套件之後
  • 是否 Hotfix 套件就會取代任何其他 Hotfix 套件
  • 您必須在是否做任何登錄變更
  • 包含在 Hotfix 套件中的檔案

徵狀

您在 Microsoft SQL Server 2005 中有複雜的查詢。查詢的執行計劃包含 半聯結 運算子。您在執行查詢時查詢效能是查詢的緩慢相較於 Microsoft SQL Server 2000。

附註通常,查詢中包含 IN 關鍵字或 EXISTS 關鍵字時,會產生 半聯結 運算子。

發生的原因

查詢最佳化器會產生許多多個執行計劃比 SQL Server 2000,就會發生這個問題。因此,查詢最佳化器可能會逾時時間。發生這種情況時查詢最佳化器會停止搜尋的執行計劃之前查詢最佳化器完全搜尋所有可能的執行計劃。

若要判斷查詢最佳化器逾時,搜尋 StatementOptmEarlyAbortReason = 時間" XML 輸出中的顯示計劃的執行計劃的運算式。

解決方案

Hotfix 資訊

Microsoft 提供支援的 Hotfix。不過,此 Hotfix 旨在修正本文中所述隨問題。只會發生此特定問題的系統套用此 Hotfix。這個 Hotfix 可能會接受額外的測試。因此,如果您不會嚴重影響這個問題,我們建議您等候下一個包含此 Hotfix 的軟體更新。

如果此 Hotfix 可供下載,您可在本知識庫文件的頂端找到「 可用的 Hotfix 下載 」區段。如果本節 Does Not Appear 請連絡[ Microsoft 客戶服務 ] 和 [ 支援 ] 以取得此 Hotfix。

附註如果發生其他問題,或如果需要任何疑難排解,您可能必須建立個別的服務要求。和此 Hotfix 無關的額外支援問題適用一般的支援費用。如需 Microsoft 客戶服務支援部門電話號碼的完整清單或要建立個別的服務要求,請造訪下列 Microsoft 網站:
http://support.microsoft.com/contactus/?ws=support
附註「 下載 Hotfix 」 表單會顯示此 Hotfix 會出現,以供使用的語言。如果您沒有看到您的語言,是因為此 Hotfix 是不適用您的語言。

必要條件

  • SQL Server 2005 Service Pack 2

    如需有關如何取得 SQL Server 2005 Service Pack 2 的資訊,按一下下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項:
    913089如何取得最新的 Service Pack,SQL Server 2005 的

重新啟動資訊

您沒有套用此 Hotfix 之後重新啟動電腦。

Hotfix 取代資訊

此 Hotfix 不會取代其他 Hotfix。

登錄資訊

您沒有變更登錄。

檔案資訊

此 Hotfix 包含只需修正本文所列問題的那些檔案。此 Hotfix 並未包含必須將產品完整更新至最新版組建的所有檔案。

此 Hotfix 的英文版在檔案屬性 (或更新版本的檔案屬性) 如下列表格中所列。這些檔案的日期和時間為 Coordinated Universal Time (UTC)。當您檢視檔案資訊時,會將它轉換為當地時間。若要到 UTC 與當地時間差異使用在 [日期及時間 中項目控制台中的 [時區] 索引標籤]。
SQL Server 2005 32 位元版本
摺疊此表格展開此表格
檔案名稱檔案版本檔案大小日期時間平台
Chsbrkr.dll12.0.7822.01,684,8402007 年六月 22 日09: 22x86
Chtbrkr.dll12.0.7822.06,112,6162007 年六月 22 日09: 22x86
Databasemailprotocols.dll9.0.3182.046,4482007 年七月 10 日04: 56x86
Fteref.dll12.0.7822.0446,4642007 年六月 22 日09: 22x86
Infosoft.dll12.0.7822.0468,3282007 年六月 22 日09: 22x86
Korwbrkr.dll12.0.7822.071,0162007 年六月 22 日09: 22x86
Langwrbk.dll12.0.7822.0136,5522007 年六月 22 日09: 22x86
Microsoft.analysisservices.dll9.0.3182.01,217,9042007 年七月 10 日04: 56x86
Microsoft.sqlserver.maintenanceplantasks.dll9.0.3182.0296,3042007 年七月 10 日04: 56x86
Msfte.dll12.0.7822.02,430,3122007 年六月 22 日09: 22x86
Msftefd.exe12.0.7822.066,9202007 年六月 22 日09: 22x86
Msftepxy.dll12.0.7822.095,5922007 年六月 22 日09: 22x86
Msftesql.exe12.0.7822.095,5922007 年六月 22 日09: 22x86
Msir5jp.dll5.0.2130.03,159,9122007 年六月 22 日09: 22x86
Msmdlocal.dll9.0.3182.015,948,1442007 年七月 10 日04: 56x86
Mssqlsystemresource.ldf不適用524,2882007 年七月 10 日01: 45不適用
Mssqlsystemresource.mdf不適用40,108,0322007 年七月 10 日01: 45不適用
Nlhtml.dll12.0.7822.0124,2642007 年六月 22 日09: 22x86
Nls400.dll5.0.4217.012,240,7442007 年六月 22 日09: 22x86
Odsole70.dll2005.90.3182.059,2482007 年七月 10 日04: 56x86
Query.dll12.0.7822.048,4882007 年六月 22 日09: 22x86
Rdistcom.dll2005.90.3182.0644,9762007 年七月 10 日04: 56x86
Replmerg.exe2005.90.3182.0320,8802007 年七月 10 日04: 56x86
Replrec.dll2005.90.3182.0784,7522007 年七月 10 日04: 56x86
Sqlaccess.dll2005.90.3182.0350,5762007 年七月 10 日04: 56x86
Sqlagent90.exe2005.90.3182.0349,5522007 年七月 10 日04: 56x86
Sqlservr.exe2005.90.3182.029,195,1202007 年七月 10 日04: 56x86
Sqlwep.dll2005.90.3182.090,9922007 年七月 10 日04: 56x86
Sqsrvres.dll2005.90.3182.070,5122007 年七月 10 日04: 56x86
Sysdbupg.sql不適用510,6222007 年六月 13 日01: 18不適用
Thawbrkr.dll12.0.7822.0206,1842007 年六月 22 日09: 22x86
Xmlfilt.dll12.0.7822.0197,9922007 年六月 22 日09: 22x86
Xpstar90.dll2005.90.3182.0298,8642007 年七月 10 日04: 56x86
x x64 版本的 SQL Server 2005
摺疊此表格展開此表格
檔案名稱檔案版本檔案大小日期時間平台
Chsbrkr.dll12.0.7822.01,694,0562007 年六月 22 日10: 51x64
Chtbrkr.dll12.0.7822.06,109,0322007 年六月 22 日10: 51x64
Databasemailprotocols.dll9.0.3182.046,4482007 年七月 10 日07: 51x86
Fteref.dll12.0.7822.0433,1522007 年六月 22 日10: 51x64
Infosoft.dll12.0.7822.0621,4162007 年六月 22 日10: 51x64
Korwbrkr.dll12.0.7822.0101,7362007 年六月 22 日10: 51x64
Langwrbk.dll12.0.7822.0236,9042007 年六月 22 日10: 51x64
Microsoft.analysisservices.dll9.0.3182.01,217,9042007 年七月 10 日04: 56x86
Microsoft.sqlserver.maintenanceplantasks.dll9.0.3182.0296,3042007 年七月 10 日04: 56x86
Msfte.dll12.0.7822.03,808,1042007 年六月 22 日10: 51x64
Msftefd.exe12.0.7822.099,1762007 年六月 22 日10: 51x64
Msftepxy.dll12.0.7822.0127,3362007 年六月 22 日10: 51x64
Msftesql.exe12.0.7822.0158,5682007 年六月 22 日10: 51x64
Msir5jp.dll5.0.2130.03,421,5442007 年六月 22 日10: 51x64
Msmdlocal.dll9.0.3182.015,948,1442007 年七月 10 日04: 56x86
Mssqlsystemresource.ldf不適用524,2882007 年七月 10 日01: 45不適用
Mssqlsystemresource.mdf不適用40,108,0322007 年七月 10 日01: 45不適用
Nlhtml.dll12.0.7822.0191,8482007 年六月 22 日10: 51x64
Nls400.dll5.0.4217.014,101,3522007 年六月 22 日10: 51x64
Odsole70.dll2005.90.3182.090,4802007 年七月 10 日07: 51x64
Query.dll12.0.7822.068,4562007 年六月 22 日10: 51x64
Rdistcom.dll2005.90.3182.0828,7842007 年七月 10 日07: 51x64
Replmerg.exe2005.90.3182.0417,6482007 年七月 10 日07: 51x64
Replrec.dll2005.90.3182.01,011,5682007 年七月 10 日07: 51x64
Sqlaccess.dll2005.90.3182.0357,7442007 年七月 10 日07: 51x86
Sqlagent90.exe2005.90.3182.0429,4242007 年七月 10 日07: 51x64
Sqlservr.exe2005.90.3182.039,679,3442007 年七月 10 日07: 51x64
Sqlwep.dll2005.90.3182.0123,7602007 年七月 10 日07: 51x64
Sqlwep.dll2005.90.3182.090,9922007 年七月 10 日04: 56x86
Sqsrvres.dll2005.90.3182.083,3122007 年七月 10 日07: 51x64
Sysdbupg.sql不適用510,6222007 年六月 13 日01: 18不適用
Thawbrkr.dll12.0.7822.0209,7682007 年六月 22 日10: 51x64
Xmlfilt.dll12.0.7822.0271,2082007 年六月 22 日10: 51x64
Xpstar90.dll2005.90.3182.0550,2562007 年七月 10 日07: 51x64
SQL Server 2005 Itanium 架構版本
摺疊此表格展開此表格
檔案名稱檔案版本檔案大小日期時間平台
Chsbrkr.dll12.0.7822.01,883,4962007 年六月 22 日10: 06IA 64
Chtbrkr.dll12.0.7822.06,153,5762007 年六月 22 日10: 06IA 64
Databasemailprotocols.dll9.0.3182.046,4482007 年七月 10 日13: 01x86
Fteref.dll12.0.7822.0433,1522007 年六月 22 日10: 06IA 64
Infosoft.dll12.0.7822.01,915,2402007 年六月 22 日10: 06IA 64
Korwbrkr.dll12.0.7822.0182,6322007 年六月 22 日10: 06IA 64
Langwrbk.dll12.0.7822.0333,1602007 年六月 22 日10: 06IA 64
Microsoft.analysisservices.dll9.0.3182.01,217,9042007 年七月 10 日04: 56x86
Microsoft.sqlserver.maintenanceplantasks.dll9.0.3182.0296,3042007 年七月 10 日04: 56x86
Msfte.dll12.0.7822.07,072,1042007 年六月 22 日10: 06IA 64
Msftefd.exe12.0.7822.0173,4162007 年六月 22 日10: 06IA 64
Msftepxy.dll12.0.7822.0135,5282007 年六月 22 日10: 06IA 64
Msftesql.exe12.0.7822.0294,7602007 年六月 22 日10: 06IA 64
Msir5jp.dll5.0.2130.03,824,4882007 年六月 22 日10: 06IA 64
Msmdlocal.dll9.0.3182.049,907,0562007 年七月 10 日13: 01IA 64
Mssqlsystemresource.ldf不適用524,2882007 年七月 10 日01: 45不適用
Mssqlsystemresource.mdf不適用40,108,0322007 年七月 10 日01: 45不適用
Nlhtml.dll12.0.7822.0295,7842007 年六月 22 日10: 06IA 64
Nls400.dll5.0.4217.014,750,0562007 年六月 22 日10: 06IA 64
Odsole70.dll2005.90.3182.0179,5682007 年七月 10 日13: 01IA 64
Query.dll12.0.7822.0123,2402007 年六月 22 日10: 06IA 64
Rdistcom.dll2005.90.3182.01,885,5522007 年七月 10 日13: 01IA 64
Replmerg.exe2005.90.3182.0957,2962007 年七月 10 日13: 01IA 64
Replrec.dll2005.90.3182.02,145,1362007 年七月 10 日13: 01IA 64
Sqlaccess.dll2005.90.3182.0352,1122007 年七月 10 日13: 01x86
Sqlagent90.exe2005.90.3182.01,254,2562007 年七月 10 日13: 01IA 64
Sqlservr.exe2005.90.3182.072,819,5682007 年七月 10 日13: 01IA 64
Sqlwep.dll2005.90.3182.0221,0402007 年七月 10 日13: 01IA 64
Sqlwep.dll2005.90.3182.090,9922007 年七月 10 日04: 56x86
Sqsrvres.dll2005.90.3182.0147,3122007 年七月 10 日13: 01IA 64
Sysdbupg.sql不適用510,6222007 年六月 13 日01: 18不適用
Thawbrkr.dll12.0.7822.0253,2882007 年六月 22 日10: 06IA 64
Xmlfilt.dll12.0.7822.0445,8002007 年六月 22 日10: 06IA 64
Xpstar90.dll2005.90.3182.0966,0002007 年七月 10 日13: 01IA 64

其他可行方案

若要解決這個問題,請避免使用 IN 關鍵字或 EXISTS 關鍵字。

狀況說明

Microsoft 已確認<適用於>一節所列之 Microsoft 產品確實有此問題。

其他相關資訊

套用此 Hotfix 之後必須啟用追蹤旗標 4102 和追蹤旗標 4118,以便行為會還原成在 SQL Server 2000 行為。但是,我們建議您之前使用方法所述 < 其他可行方案 > 一節中套用此 Hotfix。

針對在伺服器上的連接或伺服器上的所有連線,您必須使用這些追蹤旗標。如果您在啟動時設定追蹤旗標,追蹤旗標會影響伺服器上的所有連線。

如需有關如何設定追蹤旗標,請參閱 SQL Server 2005 線上叢書 》 中的下列主題的詳細資訊:
  • DBCC TRACEON (Transact-SQL)
  • 追蹤旗標 (Transact-SQL)
  • DBCC TRACESTATUS (Transact-SQL)
  • 重大變更 SQL Server 2005 中的資料庫引擎功能
如 SQL Server 更新命名的結構描述的更多有關,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
822499Microsoft SQL Server 軟體更新套件的新命名結構描述

如需有關軟體更新術語的詳細資訊,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
824684用來描述 Microsoft 軟體更新標準術語的說明

屬性

文章編號: 940128 - 上次校閱: 2007年11月21日 - 版次: 2.4
這篇文章中的資訊適用於:
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL Server 2005 Enterprise Edition
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Standard X64 Edition
  • Microsoft SQL Server 2005 Standard Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Enterprise X64 Edition
  • Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems
關鍵字:?
kbmt kbautohotfix kbsql2005engine kbexpertiseadvanced kbfix kbpubtypekc kbqfe kbhotfixserver KB940128 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:940128
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