CORRECTIF : une instruction SELECT qui contient calculées colonnes et valeurs de condition de filtre non valide peuvent provoquer une violation d'accès

IMPORTANT : Cet article est issu du système de traduction automatique mis au point par Microsoft (http://support.microsoft.com/gp/mtdetails). Un certain nombre d’articles obtenus par traduction automatique sont en effet mis à votre disposition en complément des articles traduits en langue française par des traducteurs professionnels. Cela vous permet d’avoir accès, dans votre propre langue, à l’ensemble des articles de la base de connaissances rédigés originellement en langue anglaise. Les articles traduits automatiquement ne sont pas toujours parfaits et peuvent comporter des erreurs de vocabulaire, de syntaxe ou de grammaire (probablement semblables aux erreurs que ferait une personne étrangère s’exprimant dans votre langue !). Néanmoins, mis à part ces imperfections, ces articles devraient suffire à vous orienter et à vous aider à résoudre votre problème. Microsoft s’efforce aussi continuellement de faire évoluer son système de traduction automatique.

La version anglaise de cet article est la suivante: 824227
Cet article a été archivé. Il est proposé « en l'état » et ne sera plus mis à jour.
Bogue #: 469684 (SQL Server 8.0)
Symptômes
Lorsque vous exécutez une instruction SELECT sur une table qui contienne un ou plusieurs calculée colonnes et l'instruction SELECT contient des valeurs de paramètre non valide pour les conditions du filtre, une violation d'accès peut se produire.

L'instruction SELECT qui contient les valeurs de paramètre non valide peut-être s'exécuter correctement si Microsoft SQL Server 2000 contient déjà un plan de l'exécution de requête qui a été généré à l'aide de paramètres valides pour la même instruction SELECT. Si vous effacez le cache de procédure SQL Server et réexécutez l'instruction SELECT avec des valeurs de paramètre non valide, le problème peut se produire à nouveau.

Lorsque la violation d'accès se produit, vous pouvez remarquer un fichier de vidage de pile qui est semblable au suivant :
* ********************************************************************************* 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

Vous pouvez également remarquer un fichier de vidage de pile court qui est semblable au suivant :

******************************************************************************** * ------------------------------------------------------------------------------- * 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)
Résolution

Informations sur le service pack

Pour résoudre ce problème, procurez-vous le dernier service pack Microsoft SQL Server 2000. Pour plus d'informations, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
290211 Comment obtenir le dernier pack de service SQL Server 2000

Informations sur le correctif

La version anglaise de ce correctif dispose des attributs de fichier (ou version ultérieure) répertoriés dans le tableau suivant. Les dates et heures de ces fichiers sont exprimées en coordinated universal temps (UTC). Lorsque vous affichez les informations de fichier, il est convertie en heure locale. Pour connaître le décalage entre l'heure UTC et l'heure locale, utilisez l'onglet Fuseau horaire dans l'outil Date et heure du Panneau de configuration.
   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      
note En raison des dépendances de fichiers, la fonctionnalité qui contient ces fichiers ou correctif plus récent peut également contenir des fichiers supplémentaires.
Statut
Microsoft a confirmé qu'il s'agit d'un problème les produits Microsoft répertoriés au début de cet article produits. Ce problème a été corrigé dans Microsoft SQL Server 2000 Service Pack 4.
Références
Pour plus d'informations, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
824684 Description de la terminologie standard utilisée pour décrire les mises à jour logicielles Microsoft
arguments non valides des paramètres incorrects

Avertissement : Cet article a été traduit automatiquement.

Propriétés

ID d'article : 824227 - Dernière mise à jour : 01/17/2015 05:19:31 - Révision : 3.3

Microsoft SQL Server 2000 Édition Développeur, Microsoft SQL Server 2000 Standard, Microsoft SQL Server 2000 Édition Entreprise, Microsoft SQL Server 2000 Édition Personelle, 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 KbMtfr
Commentaires