FIX: 一个 SELECT 语句包含计算列和无效的筛选器条件的值可能会导致访问冲突

注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。

点击这里察看该文章的英文版: 824227
本文已归档。它按“原样”提供,并且不再更新。
错误 #: 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 服务包

修补程序信息

此修补程序的英文版具有文件属性 (或更高版本) 下表中列出。其格式为协调通用时间 (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      
注意由于存在文件依赖性最新的修补程序或功能,它包含这些文件可能还包含其他文件。
状态
Microsoft 已经确认这是本文"适用于"一节中列出的 Microsoft 产品中的问题。Microsoft SQL Server 2000 Service Pack 4 中,第一次已得到纠正此问题。
参考
有关更多的信息请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
824684用于描述 Microsoft 软件更新的标准术语的说明
参数不正确的参数无效

警告:本文已自动翻译

属性

文章 ID:824227 - 上次审阅时间:01/17/2015 05:19:32 - 修订版本: 3.3

Microsoft SQL Server 2000 Developer Edition, Microsoft SQL Server 2000 标准版, 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

  • kbnosurvey kbarchive kbmt kbhotfixserver kbqfe kbquery kbtsql kbsqlserv2000presp4fix kbfix kbbug KB824227 KbMtzh
反馈