修正: 在 SQL Server 2008 R2,就會引發錯誤時 SQL Server 效能條件警示

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

按一下這裡查看此文章的英文版本:2587511
Microsoft 會將單一可下載檔案 Microsoft SQL Server 2008 R2 Service Pack 1 (SP1) 修正程式。修正程式是累積的因為每個新版本會包含所有 hotfix 和隨附之前 SQL Server 2008 R2 Service Pack 1 (SP1) 的更新版本的所有安全性更新。
徵狀
當 Microsoft SQL Server 2008 R2 中引發的 SQL Server 效能條件警示時,您可能會收到下列錯誤訊息:
訊息 512,層次 16,狀態 1,程序 sp_sqlagent_get_perf_counters,行 40
子查詢會傳回 1 個以上的值。當子查詢,並不會允許這 =、! =、 <,> </,> <= ,="">,> = 或當子查詢做為運算式。</=>
此外,錯誤訊息會記錄在此情況下 SQL Server 代理程式錯誤記錄檔中。

附註 Microsoft SQL Server 2008年也會發生這個問題。
發生的原因
發生這個問題的子查詢 msdb.dbo.sp_sqlagent_get_perf_counters 系統預存程序會計算計數器的值不正確。

子查詢缺少內部聯結關聯性 [] object_name 子查詢中的條件中的資料行。因此,不正確地傳回多個資料列,而 「 徵狀 〉 一節所述的問題,就會發生。

附註msdb.dbo.sp_sqlagent_get_perf_counters 當引發的 SQL Server 效能條件警示時,系統預存程序執行。
解決方案

累積更新資訊

SQL Server 2008 R2 sp1 的累積更新套件 3

累積更新套件 3 於第一次發行的修正這個問題。如需有關如何取得此累積更新套件 SQL Server 2008 R2 sp1 的詳細資訊,請按一下下面的文件編號,檢視 「 Microsoft 知識庫 」 中的文件:
2591748 SQL Server 2008 R2 sp1 的累積更新套件 3
附註 因為組建是累計的每個新的更新版本會包含所有的 hotfix,所有安全性更新隨附之前 SQL Server 2008 R2 SP1 都更新版本。我們建議您考慮將套用最新的更新版本,其中包含此 hotfix。如需詳細資訊,按一下下面的文件編號,檢視 「 Microsoft 知識庫 」 中的文件:
2567616 SQL Server 2008 R2 SQL Server 2008 R2 SP1 發行之後所發行的組建


其他可行方案
若要解決這個問題,更新的子查詢 msdb.dbo.sp_sqlagent_get_perf_counters 系統預存程序。若要這樣做,新增下列條件,以 位置 四個的子查詢中所使用的子句 [值] 資料行計算:
(spi1.[object_name] = spi2.[object_name])
新增條件後,子查詢如下所示:
SELECT CASE spi2.cntr_value WHEN 0 THEN 1 ELSE spi2.cntr_value ENDFROM sys.dm_os_performance_counters spi2WHERE (spi1.[object_name] = spi2.[object_name])AND (spi1.counter_name + ' ' = SUBSTRING(spi2.counter_name, 1, PATINDEX('% Base%', spi2.counter_name)))AND (spi1.instance_name = spi2.instance_name)AND (spi2.cntr_type = @perfTypeLargeRawBase

狀況說明
Microsoft 已確認這是 「 套用 」 一節所列的 Microsoft 產品中的問題。

警告:本文為自動翻譯

內容

文章識別碼:2587511 - 最後檢閱時間:10/17/2011 11:22:00 - 修訂: 1.0

Microsoft SQL Server 2008 Enterprise, Microsoft SQL Server 2008 Enterprise Evaluation, Microsoft SQL Server 2008 R2 Datacenter, Microsoft SQL Server 2008 R2 Developer, Microsoft SQL Server 2008 R2 Enterprise

  • kbqfe kbfix kbexpertiseadvanced kbsurveynew kbmt KB2587511 KbMtzh
意見反應