FIX: 在彙總函式內的使用者定義函式的多個呼叫可能會傳回不正確的結果

文章翻譯 文章翻譯
文章編號: 288957 - 檢視此文章適用的產品。
Bug #: 236595 (SHILOH_BUGS)
全部展開 | 全部摺疊

在此頁中

徵狀

如果下列條件全部成立,SQL Server 可能會傳回查詢結果不正確:
  • 查詢中包含兩個或多個參照到相同的聚合函數。
  • 這些彙總函式採用做為其參數從相同的使用者自訂函數 (UDF) 的呼叫結果。
  • UDF 的呼叫傳遞相同的第一個參數。
  • UDF 採用兩個或多個參數和它會傳回這些次要參數的值而定的結果。

發生的原因

最佳化器會嘗試在查詢中尋找重複的彙總函數,使每個唯一的彙總只計算一次。該程式碼會列入考量次要參數傳遞給一個 UDF,且可能無法正確識別為對等用法的兩個彙總失敗。

解決方案

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

Hotfix

注意: 之前 Microsoft SQL Server 2000 Service Pack 1,所以建立的下列 Hotfix。

此修正程式的英文版應該具有下列檔案屬性或更新版本:
   Version      File name       Platform
   -------------------------------------

   8.00.251     s80251i.exe     x86

				

狀況說明

Microsoft 已確認這是在本文開頭所列之 Microsoft 產品中的問題。這個問題,首先已經在 Microsoft SQL Server 2000 Service Pack 1 中獲得修正。

其他相關資訊

下列範例會示範此問題。

CREATE TABLE functest (c1 int NULL, c2 int NULL, c3 int NULL,
 c4 int NULL, c5 int NULL, c6 int NULL)
GO
INSERT INTO functest VALUES(1,2,3,4,5,6)
go
CREATE FUNCTION t3 (@one int, @two int, @three int) RETURNS int AS
BEGIN
  RETURN (@one*@two*@three)
END
GO
--This works correctly, returns 720
SELECT avg(dbo.t3(c1,c2,c3)) * avg(dbo.t3(c4,c5,c6)) correct FROM functest
go
--This is incorrect, returns 36, should be 180
SELECT avg(dbo.t3(c1,c2,c3)) * avg(dbo.t3(c1,c5,c6)) incorrect FROM functest
go
--If you swap c1 and c6, the results are correct! (180)
SELECT avg(dbo.t3(c1,c2,c3)) * avg(dbo.t3(c6,c5,c1)) correct FROM functest
				
請注意取得不正確的結果,如果 UDF 的兩個參考傳遞相同的第一個參數是為資料行名稱或函式的常值。

屬性

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