FIX: A 的 SELECT 陳述式,包含計算資料行,無效的篩選條件值可能會導致存取違規

文章翻譯 文章翻譯
文章編號: 824227 - 檢視此文章適用的產品。
Bug #: 469684 (SQL Server 8.0)
全部展開 | 全部摺疊

在此頁中

徵狀

當您執行 SELECT 陳述式包含一個資料表上或更多計算資料行和 SELECT 陳述式包含的篩選條件無效的參數值時,可能會發生存取違規。

如果 Microsoft SQL Server 2000 已經儲存由使用有效的參數進行相同的 SELECT 陳述式產生的查詢執行計劃,包含無效的參數值的 SELECT 陳述式可能順利執行。如果您清除 [SQL Server 程序快取,並再執行 SELECT 陳述式使用無效的參數值,問題可能會再發生。

存取違規時您可能會注意到類似下列的堆疊傾印檔案:
* *******************************************************************************
*
* BEGIN STACK DUMP: 
* 05/14/03 21:31:23 spid 63 
* 
* Exception Address = 00747D1A (CConvertCtx::PboWithComputedColumnDependencies + 000000E7 Line 0+00000000) 
* Exception Code = c0000005 EXCEPTION_ACCESS_VIOLATION 
* Access Violation occurred reading address 00000014

您也可能會注意到類似下列的簡短的堆疊傾印檔案:

******************************************************************************** 
* ------------------------------------------------------------------------------- 
* Short Stack Dump 
* 00747D1A Module(sqlservr+00347D1A) (CConvertCtx::PboWithComputedColumnDependencies+000000E7)
* 004C2F1D Module(sqlservr+000C2F1D) (CPhyOp_Fetch::PqteConvert+00000452) 
* 0044D9B4 Module(sqlservr+0004D9B4) (COptExpr::PqteConvert+000000BC) 
* 0046C8FC Module(sqlservr+0006C8FC) (CConvertCtx::PqteConvertChild+0000002D) 
* 004797DF Module(sqlservr+000797DF) (CPhyOp_ComputeScalar::PqteConvert+00000043)
* 0044D9B4 Module(sqlservr+0004D9B4) (COptExpr::PqteConvert+000000BC) 
* 0046C8FC Module(sqlservr+0006C8FC) (CConvertCtx::PqteConvertChild+0000002D) 
* 0074EDD8 Module(sqlservr+0034EDD8) (CPhyOp_MergeUnion::PqteConvert+0000004F) 
* 0044D9B4 Module(sqlservr+0004D9B4) (COptExpr::PqteConvert+000000BC) 
* 0046C8FC Module(sqlservr+0006C8FC) (CConvertCtx::PqteConvertChild+0000002D) 
* 004DE5C1 Module(sqlservr+000DE5C1) (CPhyOp_StreamGbAgg::PqteConvert+00000058)
* 0044D9B4 Module(sqlservr+0004D9B4) (COptExpr::PqteConvert+000000BC) 
* 0046C8FC Module(sqlservr+0006C8FC) (CConvertCtx::PqteConvertChild+0000002D) 
* 004797DF Module(sqlservr+000797DF) (CPhyOp_ComputeScalar::PqteConvert+00000043)
* 0044D9B4 Module(sqlservr+0004D9B4) (COptExpr::PqteConvert+000000BC) 
* 0046C8FC Module(sqlservr+0006C8FC) (CConvertCtx::PqteConvertChild+0000002D) 
* 00472235 Module(sqlservr+00072235) (CPhyOp_Top::PqteConvert+000000CE) 
* 0044D9B4 Module(sqlservr+0004D9B4) (COptExpr::PqteConvert+000000BC) 
* 0046C8FC Module(sqlservr+0006C8FC) (CConvertCtx::PqteConvertChild+0000002D) 
* 00472235 Module(sqlservr+00072235) (CPhyOp_Top::PqteConvert+000000CE) 
* 0044D9B4 Module(sqlservr+0004D9B4) (COptExpr::PqteConvert+000000BC) 
* 0046C8FC Module(sqlservr+0006C8FC) (CConvertCtx::PqteConvertChild+0000002D) 
* 00469726 Module(sqlservr+00069726) (CPhyOp_StreamUpdate::PqteConvert+0000293E)
* 0044D9B4 Module(sqlservr+0004D9B4) (COptExpr::PqteConvert+000000BC) 
* 0044D820 Module(sqlservr+0004D820) (COptExpr::PqteConvertTree+00000055) 
* 00458633 Module(sqlservr+00058633) (COptContext::PcxteOptimizeQuery+000011D4)
* 0045775B Module(sqlservr+0005775B) (CQuery::Optimize+000003F9) 
* 00457536 Module(sqlservr+00057536) (CQuery::Optimize+00000030) 
* 00455182 Module(sqlservr+00055182) (CCvtTree::PqryFromTree+0000029D) 
* 00454F30 Module(sqlservr+00054F30) (BuildQueryFromTree+00000046) 
* 00454E9D Module(sqlservr+00054E9D) (CStmtQuery::InitQuery+0000013E) 
* 004632DF Module(sqlservr+000632DF) (CStmtDML::InitNormal+0000011B) 
* 00463225 Module(sqlservr+00063225) (CStmtDML::Init+00000033) 
* 004458F7 Module(sqlservr+000458F7) (CCompPlan::FCompileStep+00000C4C) 
* 0044AB41 Module(sqlservr+0004AB41) (CProchdr::FCompile+00000D23) 
* 0041BF21 Module(sqlservr+0001BF21) (CSQLSource::FTransform+0000034C) 
* 0044CE55 Module(sqlservr+0004CE55) (CSQLStrings::FTransform+000001A1) 
* 0041B8EF Module(sqlservr+0001B8EF) (CSQLSource::Execute+0000015B) 
* 005000B1 Module(sqlservr+001000B1) (ExecuteSql+00000284) 
* 005F15DE Module(sqlservr+001F15DE) (CSpecProc::ExecuteSpecial+00000293) 
* 005F10DD Module(sqlservr+001F10DD) (CXProc::Execute+000000A3) 
* 005F334E Module(sqlservr+001F334E) (CSQLSource::Execute+000003C0) 
* 00438F0B Module(sqlservr+00038F0B) (execrpc+00000507) 
* 0043816D Module(sqlservr+0003816D) (execute_rpc+00000019) 
* 00427001 Module(sqlservr+00027001) (process_commands+00000232) 
* 41075002 Module(UMS+00005002) (ProcessWorkRequests+00000272) 
* 41074698 Module(UMS+00004698) (ThreadStartRoutine+00000098) 
* 7800C9EB Module(MSVCRT+0000C9EB) (beginthread+000000CE) 
* 77E887DD Module(KERNEL32+000087DD) (GetModuleFileNameA+000001D1)

解決方案

服務套件資訊

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

Hotfix 資訊

此 Hotfix 的英文版具有檔案屬性 (或更新) 中如下表所列。這些檔案的日期和時間為 Coordinated Universal Time (UTC)。當您檢視檔案資訊時,會將它轉換為當地時間。若要到 UTC 與當地時間差異使用 [中日期] 和 [時間] 工具,在 [控制台] 中的 [時區] 索引標籤]。
   Date         Time   Version             Size   File name
   -----------------------------------------------------------------------
   31-May-2003  06:15  2000.80.818.0      78,400  Console.exe      
   24-Jun-2003  12:31  2000.80.818.0      33,340  Dbmslpcn.dll     
   24-Apr-2003  13:42                    786,432  Distmdl.ldf
   24-Apr-2003  13:42                  2,359,296  Distmdl.mdf
   29-Jan-2003  13:25                        180  Drop_repl_hotfix.sql
   23-Jun-2003  10:10  2000.80.837.0   1,557,052  Dtsui.dll        
   23-Jun-2003  10:10  2000.80.837.0     639,552  Dtswiz.dll       
   23-Apr-2003  14:21                    747,927  Instdist.sql
   02-May-2003  13:26                      1,581  Inst_repl_hotfix.sql
   07-Feb-2003  18:10  2000.80.765.0      90,692  Msgprox.dll      
   31-Mar-2003  13:37                      1,873  Odsole.sql
   04-Apr-2003  13:16  2000.80.800.0      62,024  Odsole70.dll     
   07-May-2003  08:11  2000.80.819.0      25,144  Opends60.dll     
   02-Apr-2003  09:18  2000.80.796.0      57,904  Osql.exe         
   02-Apr-2003  10:45  2000.80.797.0     279,104  Pfutil80.dll     
   22-May-2003  10:27                     19,195  Qfe469571.sql
   12-Jun-2003  04:07                  1,083,989  Replmerg.sql
   04-Apr-2003  09:23  2000.80.798.0     221,768  Replprov.dll     
   07-Feb-2003  18:10  2000.80.765.0     307,784  Replrec.dll      
   04-May-2003  11:35                  1,085,874  Replsys.sql
   31-May-2003  12:31  2000.80.818.0     492,096  Semobj.dll       
   31-May-2003  05:57  2000.80.818.0     172,032  Semobj.rll
   28-May-2003  11:59                    115,944  Sp3_serv_uni.sql
   31-May-2003  12:31  2000.80.818.0   4,215,360  Sqldmo.dll       
   07-Apr-2003  05:14                     25,172  Sqldumper.exe    
   19-Mar-2003  05:50  2000.80.789.0      28,672  Sqlevn70.rll
   01-Jul-2003  11:48  2000.80.834.0     180,736  Sqlmap70.dll     
   07-Feb-2003  18:10  2000.80.765.0      57,920  Sqlrepss.dll     
   23-Jun-2003  10:10  2000.80.837.0   7,553,105  Sqlservr.exe     
   07-Feb-2003  18:10  2000.80.765.0      45,644  Sqlvdi.dll       
   24-Jun-2003  12:31  2000.80.818.0      33,340  Ssmslpcn.dll     
   31-May-2003  12:31  2000.80.818.0      82,492  Ssnetlib.dll     
   31-May-2003  12:31  2000.80.818.0      25,148  Ssnmpn70.dll     
   31-May-2003  12:31  2000.80.818.0     158,240  Svrnetcn.dll     
   31-May-2003  06:29  2000.80.818.0      76,416  Svrnetcn.exe     
   30-Apr-2003  11:22  2000.80.816.0      45,132  Ums.dll          
   01-Jul-2003  11:49  2000.80.834.0      98,816  Xpweb70.dll      
附註由於檔案相依性最新版 Hotfix 或包含這些檔案的功能也可能包含其他檔案。

狀況說明

Microsoft 已確認這是本文 < 適用於 > 一節中所列的 Microsoft 產品中的問題。這個問題,首先已經在 Microsoft SQL Server 2000 服務套件 4 中獲得修正。

?考

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

屬性

文章編號: 824227 - 上次校閱: 2007年11月2日 - 版次: 3.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 kbhotfixserver kbqfe kbquery kbtsql kbsqlserv2000presp4fix kbfix kbbug KB824227 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:824227
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