FIX: [@ @ ERROR 系統函式可能傳回不正確的值當您執行 Transact-SQL 陳述式,在 SQL Server 2000 32 位元或在 SQL Server 2000 64 位元會平行執行計劃

文章翻譯 文章翻譯
文章編號: 890925 - 檢視此文章適用的產品。
Bug #: 471094 (SQL Server 8.0)



全部展開 | 全部摺疊

在此頁中

文件內容

結論

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

徵狀

藉由使用平行執行計劃執行 Transact-SQL 陳述式時,Microsoft SQL Server 2000 可能會不 @ @ ERROR 系統函數值正確當 Transact-SQL 陳述式失敗時或當 SQL Server 會偵測到錯誤的設定。如果您檢查 Transact-SQL 陳述式執行後您會看到的請立即,@ @ ERROR 系統函式所傳回的值 @ @ ERROR 函數會傳回值為零,即使查詢造成非零錯誤。

例如下列的 Transact-SQL 陳述式可能仍然執行 DELETE 陳述式雖然 INSERT 陳述式失敗時它會使用平行執行計劃:
INSERT INTO table2 SELECT * FROM table1
IF ( @@ERROR = 0 )
  DELETE FROM table1
筆記 平行執行計劃只發生在有兩個或多個邏輯處理器的電腦執行 SQL Server 的執行個體上。

如需清單前一個快速補充程式請參閱 「 Microsoft SQL Server 2000 post-Service Pack 3 或 Microsoft SQL Server 2000 post-Service 套件 3a Hotfix 」 一節,下列 「 Microsoft 知識庫 」 文件中:
290211如何取得最新的 SQL Server 2000 Service Pack


解決方案

服務套件資訊

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

Hotfix 資訊

必要條件

此 Hotfix 需要 SQL Server 2000 Service Pack 3 (SP3)。有關如何取得 SQL Server 2000 SP3,請參閱 「 Microsoft 知識庫 」 中下列文:
290211如何取得最新的 SQL Server 2000 Service Pack
此外,此 Hotfix 您必須具備也 SQL Server 2000 Hotfix 組建 2000.80.977 安裝。如需有關 SQL Server 2000 張貼 SP3a Hotfix 的詳細資訊建置 2000.80.977,請按一下下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項件:
888007當您嘗試安裝 SQL Server 2000 SP3 張貼 Hotfix 時,收到"的產品並沒有安裝的必要條件更新 」 錯誤訊息




重新啟動資訊

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



Hotfix 檔案資訊

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

此 Hotfix 的英文版具有檔案屬性 (或更新) 中如下表所列。這些檔案的日期和時間為 Coordinated Universal Time (UTC)。當您檢視檔案資訊時,會將它轉換為當地時間。若要到 UTC 與當地時間差異使用 [中日期] 和 [時間] 工具,在 [控制台] 中的 [時區] 索引標籤]。

SQL Server 2000 32年位元版本
   Date         Time   Version            Size    File name
   ---------------------------------------------------------------------
   01-Dec-2004  19:57  2000.80.993.0     664,128  Autoplt.dll      
   01-Dec-2004  19:57  2000.80.993.0      78,400  Console.exe
   01-Dec-2004  19:57  2000.80.993.0     332,352  Ctasksui.dll
   01-Dec-2004  19:57  2000.80.993.0     315,968  Custtask.dll     
   01-Dec-2004  19:57  2000.80.993.0      33,340  Dbmslpcn.dll     
   08-Apr-2004  21:42                    786,432  Distmdl.ldf
   08-Apr-2004  21:42                  2,359,296  Distmdl.mdf
   30-Sep-2003  22:55                        180  Drop_repl_hotfix.sql
   01-Dec-2004  19:57  2000.80.993.0   1,905,216  Dtspkg.dll       
   01-Dec-2004  19:57  2000.80.993.0     528,960  Dtspump.dll      
   01-Dec-2004  19:57  2000.80.993.0   1,557,052  Dtsui.dll        
   01-Dec-2004  19:57  2000.80.993.0     639,552  Dtswiz.dll       
   30-Sep-2003  22:55                    747,927  Instdist.sql
   30-Sep-2003  22:55                      1,581  Inst_repl_hotfix.sql
   01-Dec-2004  19:57  2000.80.993.0     352,828  Isqlw.exe        
   01-Dec-2004  19:57  2000.80.993.0      82,492  Itwiz.exe        
   01-Dec-2004  19:57  2000.80.993.0      90,692  Msgprox.dll      
   29-Oct-2004  08:16  8.11.41022.0      226,304  Mssdi98.dll      
   01-Dec-2004  19:57  2000.80.993.0      62,024  Odsole70.dll     
   01-Dec-2004  19:58  2000.80.993.0      25,144  Opends60.dll     
   01-Dec-2004  19:57  2000.80.993.0      57,904  Osql.exe         
   01-Dec-2004  19:57  2000.80.993.0     279,104  Pfutil80.dll     
   30-Sep-2003  22:48                    550,780  Procsyst.sql
   08-Apr-2004  21:42                     12,305  Qfe469315.sql
   08-Apr-2004  21:42                     19,195  Qfe469571.sql
   27-Aug-2004  00:13                      5,157  Qfe472197.sql
   01-Dec-2004  19:57  2000.80.993.0     143,940  Qrdrsvc.exe      
   01-Dec-2004  18:49                  1,106,776  Replmerg.sql
   01-Dec-2004  19:57  2000.80.993.0     221,768  Replprov.dll     
   01-Dec-2004  19:57  2000.80.993.0     307,784  Replrec.dll      
   01-Dec-2004  18:56  2000.80.993.0     159,813  Replres.rll
   27-Aug-2004  00:13                  1,086,925  Replsys.sql
   30-Sep-2003  22:55                    986,603  Repltran.sql
   25-Nov-2004  00:04                         55  Repl_uninstall.sql
   01-Dec-2004  19:57  2000.80.993.0     287,304  Rinitcom.dll     
   01-Dec-2004  19:57  2000.80.993.0      78,416  Sdiclnt.dll      
   01-Dec-2004  19:57  2000.80.993.0      66,112  Semmap.dll       
   01-Dec-2004  19:57  2000.80.993.0      57,916  Semnt.dll        
   01-Dec-2004  19:57  2000.80.993.0     492,096  Semobj.dll       
   01-Dec-2004  19:20  2000.80.993.0     172,032  Semobj.rll
   01-Dec-2004  19:57  2000.80.993.0      53,832  Snapshot.exe     
   30-Sep-2003  22:48                    117,834  Sp3_serv_uni.sql
   01-Dec-2004  19:57  2000.80.993.0      28,672  Sqlagent.dll     
   01-Dec-2004  19:57  2000.80.993.0     311,872  Sqlagent.exe     
   01-Dec-2004  19:57  2000.80.993.0     168,001  Sqlakw32.dll     
   01-Dec-2004  19:57  2000.80.993.0      33,344  Sqlctr80.dll     
   01-Dec-2004  19:57  2000.80.993.0   4,215,360  Sqldmo.dll       
   01-Dec-2004  19:57                     25,172  Sqldumper.exe    
   01-Dec-2004  18:48  2000.80.993.0      28,672  Sqlevn70.rll
   01-Dec-2004  19:57  2000.80.993.0     156,224  Sqlmaint.exe     
   01-Dec-2004  19:57  2000.80.993.0     180,792  Sqlmap70.dll     
   01-Dec-2004  19:57  2000.80.993.0     188,992  Sqlmmc.dll
   01-Dec-2004  19:12  2000.80.993.0     479,232  Sqlmmc.rll
   01-Dec-2004  19:57  2000.80.993.0     401,984  Sqlqry.dll
   01-Dec-2004  19:57  2000.80.993.0      57,920  Sqlrepss.dll     
   01-Dec-2004  19:58  2000.80.993.0   7,716,945  Sqlservr.exe     
   01-Dec-2004  19:57  2000.80.993.0     590,396  Sqlsort.dll      
   01-Dec-2004  19:57  2000.80.993.0      45,644  Sqlvdi.dll       
   01-Dec-2004  19:58  2000.80.993.0     106,588  Sqsrvres.dll
   01-Dec-2004  19:58  2000.80.993.0      33,340  Ssmsgnet.dll     
   01-Dec-2004  19:58  2000.80.993.0      33,340  Ssmslpcn.dll     
   01-Dec-2004  19:58  2000.80.993.0      33,340  Ssmsqlgc.dll     
   01-Dec-2004  19:58  2000.80.993.0      82,492  Ssnetlib.dll     
   01-Dec-2004  19:58  2000.80.993.0      25,148  Ssnmpn70.dll     
   01-Dec-2004  19:58  2000.80.993.0     123,456  Stardds.dll
   01-Dec-2004  19:58  2000.80.993.0     158,240  Svrnetcn.dll     
   01-Dec-2004  19:57  2000.80.993.0      76,416  Svrnetcn.exe     
   01-Dec-2004  19:58  2000.80.993.0      49,228  Ums.dll          
   01-Dec-2004  19:58  2000.80.993.0      74,304  Xplog70.dll      
   01-Dec-2004  19:58  2000.80.993.0      98,872  Xpweb70.dll
SQL Server 2000 64年位元版本
   Date         Time   Version            Size    File name        Platform
   ------------------------------------------------------------------------
   02-Dec-2004  03:15  2000.80.993.0      56,832  Dbmslpcn.dll     IA-64
   02-Dec-2004  03:14  2000.80.993.0     528,960  Dtspump.dll
   02-Dec-2004  03:15  2000.80.993.0     185,856  Msgprox.dll
   29-Oct-2004  08:16  8.11.41022.0      742,912  Mssdi98.dll      IA-64
   02-Dec-2004  03:15  2000.80.993.0     151,040  Odsole70.dll     IA-64
   02-Dec-2004  03:16  2000.80.993.0      27,136  Opends60.dll     IA-64
   01-Dec-2004  20:09                     19,880  Opends60.lib
   02-Dec-2004  03:15  2000.80.993.0     148,992  Osql.exe         IA-64
   02-Dec-2004  03:15  2000.80.993.0     353,280  Qrdrsvc.exe
   02-Dec-2004  03:15  2000.80.993.0     534,528  Replprov.dll     IA-64
   02-Dec-2004  03:15  2000.80.993.0     769,024  Replrec.dll
   02-Dec-2004  03:15  2000.80.993.0     650,240  Rinitcom.dll     IA-64
   02-Dec-2004  03:15  2000.80.993.0     160,768  Semmap.dll       IA-64
   02-Dec-2004  03:15  2000.80.993.0     132,608  Semnt.dll        IA-64
   02-Dec-2004  03:15  2000.80.993.0      88,576  Snapshot.exe     IA-64
   02-Dec-2004  03:14  2000.80.993.0      10,240  Sqlagent.dll     IA-64
   02-Dec-2004  03:15  2000.80.993.0   1,055,232  Sqlagent.exe
   02-Dec-2004  03:15  2000.80.993.0      90,112  Sqlboot.dll      IA-64
   02-Dec-2004  03:15  2000.80.993.0      32,256  Sqlctr80.dll     IA-64
   02-Dec-2004  03:15  2000.80.993.0     812,032  Sqldata.dll      IA-64
   02-Dec-2004  03:15  2000.80.993.0  13,845,504  Sqldmo.dll
   02-Dec-2004  03:15                     39,936  Sqldumper.exe    IA-64
   02-Dec-2004  03:15  2000.80.993.0     493,568  Sqlmaint.exe     IA-64
   02-Dec-2004  03:15  2000.80.993.0      23,040  Sqlmap70.dll     IA-64
   02-Dec-2004  03:15  2000.80.993.0     152,064  Sqlrepss.dll     IA-64
   02-Dec-2004  03:16  2000.80.993.0  25,255,936  Sqlservr.exe     IA-64
   02-Dec-2004  03:15  2000.80.993.0     616,960  Sqlsort.dll      IA-64
   02-Dec-2004  03:15  2000.80.993.0     120,320  Sqlvdi.dll       IA-64
   02-Dec-2004  03:15  2000.80.993.0     227,328  Sqsrvres.dll     IA-64
   02-Dec-2004  03:15  2000.80.993.0      53,760  Ssmslpcn.dll     IA-64
   02-Dec-2004  03:15  2000.80.993.0      59,904  Ssmsqlgc.dll     IA-64
   02-Dec-2004  03:15  2000.80.993.0     256,000  Ssnetlib.dll     IA-64
   02-Dec-2004  03:15  2000.80.993.0      20,992  Ssnmpn70.dll     IA-64
   02-Dec-2004  03:15  2000.80.993.0     430,080  Svrnetcn.dll
   02-Dec-2004  03:15  2000.80.993.0     185,856  Svrnetcn.exe     IA-64
   02-Dec-2004  03:15  2000.80.993.0     183,296  Xplog70.dll
   02-Dec-2004  03:15  2000.80.993.0     187,392  Xpweb70.dll      IA-64
   21-Jul-2004  17:38  2000.80.962.0      57,904  Osql.exe         x86
   30-Sep-2003  22:23  2000.80.760.0     269,824  Sqdedev.dll      IA-64
   01-Dec-2004  20:22  2000.80.993.0     146,432  Replres.rll
   01-Dec-2004  20:10  2000.80.993.0      19,968  Sqlevn70.rll
附註由於檔案相依性的最新 Hotfix 包含這些檔案也可能包含其他檔案。

其他可行方案

如果要解決這個問題而定,使用 [下列的其中一個方法]:
  • 使用查詢提示

    新增查詢提示 選項 (MAXDOP 1) 來防止從使用平行執行計劃的 SELECT 陳述式。
  • 使用 sp_configure 系統預存程序

    執行 sp_configure 系統預存程序為 SQL Server 執行個體設定 最大平行度] 選項為 1。若要設定 最大平行度 選項在您想要變更的 SQL Server 執行個體上執行下列 Transact-SQL 陳述式:
    exec sp_configure 'max degree of parallelism',1
    GO
    RECONFIGURE
    GO

    附註我們不建議這因為它可能會影響效能。

狀況說明

Microsoft 已確認這是在 < 適用於 > 一節中所列出的 Microsoft 產品中有錯誤。

這個問題,首先已經在 Microsoft SQL Server 2000 服務套件 4 中獲得修正。

其他相關資訊

如需命名結構描述為 Microsoft SQL Server 的詳細資訊更新,按一下下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項:
822499Microsoft SQL Server 軟體更新套件的新命名結構描述
如 Microsoft 時修正軟體,它發行之後所使用的術語的額外有關,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
824684用來描述 Microsoft 軟體更新標準術語的說明

屬性

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