CORRECTIF : vous pouvez recevoir un message d'erreur de violation d'accès lorsque vous exécutez un plan d'exécution parallèle dans SQL Server 2005

Traductions disponibles Traductions disponibles
Numéro d'article: 912885 - Voir les produits auxquels s'applique cet article
BOGUE #: 420246 (SQLBUDT)
Microsoft distribue les correctifs Microsoft SQL Server 2005 le biais comme un fichier téléchargeable. Les correctifs étant cumulatifs, chaque nouvelle version contient tous les correctifs et tous les correctifs de sécurité qui étaient fournis avec la précédente SQL Server 2005 version du correctif.
Agrandir tout | Réduire tout

Sommaire

Résumé

Cet article décrit suivants concernant cette version de correctif logiciel :
  • Les problèmes qui sont résolus par le package de correctifs
  • Conditions préalables à l'installation le package de correctifs
  • Si vous devez redémarrer l'ordinateur après avoir installé le package de correctifs
  • Si le package de correctifs est remplacé par un autre package de correctif
  • Si vous devez apporter les modifications du Registre
  • Les fichiers qui sont contenus dans le package de correctifs

Symptômes

Dans Microsoft SQL Server 2005, vous pouvez s'afficher une message d'erreur de violation d'accès lorsque les conditions suivantes sont remplies :
  • Vous créez un index qui utilise l'option IGNORE_DUP_KEY pour une table.
  • Vous exécutez une instruction INSERT qui insère une nouvelle ligne dans cet index.
  • Le plan de l'instruction INSERT est parallèle.
  • La valeur pour une des colonnes de clé de l'option IGNORE_DUP_KEY est fournie par avec un paramètre.
En outre, un message d'erreur est semblable à la suivante peut s'afficher :
Une erreur de serveur s'est produite sur la commande en cours. Les résultats, éventuel doivent être ignorées.

Résolution

Informations sur le correctif

Un correctif est disponible auprès de Microsoft. Toutefois, ce correctif est conçu pour corriger le problème décrit dans cet article. Appliquer ce correctif uniquement aux systèmes rencontrant ce problème spécifique. Ce correctif peut subir des tests supplémentaires. Par conséquent, si vous n'êtes pas gravement touché par ce problème, nous vous recommandons d'attendre la prochaine mise à jour logicielles qui contiendra ce correctif.

Si le correctif est disponible pour le téléchargement, il est une section « téléchargement correctif disponible » en haut de cet article de la base de connaissances. Si cette section n'apparaît pas, contactez le service clientèle Microsoft et de support pour obtenir le correctif.

note Si des problèmes supplémentaires se produisent ou si n'importe quel dépannage est nécessaire, vous devrez peut-être créer une demande de service distincte. Les coûts habituels du support technique s'appliqueront aux autres questions et problèmes non traités par ce correctif spécifique. Pour une liste complète des Microsoft client service et support numéros de téléphone ou pour créer une demande de service distincte, reportez-vous au site de Web Microsoft suivant :
http://support.microsoft.com/contactus/?ws=support
note L'écran de « téléchargement correctif disponible » affiche les langues pour lesquelles le correctif est disponible. Si vous ne voyez pas la langue, il est car un correctif logiciel n'est pas disponible pour cette langue.

Conditions préalables

Il n'y a aucune condition préalable de ce correctif.

Redémarrez les informations

Vous devez redémarrer l'ordinateur après avoir appliqué ce correctif.

Informations de Registre

Vous devez modifier le Registre.

Informations de fichier

Ce correctif contient uniquement les fichiers nécessaires à la résolution des problèmes décrits dans cet article. Ce correctif peut ne pas contenir tous les fichiers nécessaires à la mise à jour complètement un produit vers la dernière version.

La version anglaise de ce correctif dispose les attributs de fichier (ou attributs de fichier version ultérieure) répertoriés dans le tableau suivant. Les dates et heures de ces fichiers sont exprimées en temps universel coordonné (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'élément Date et heure du Panneau de configuration.
SQL Server 2005 pour x 86 systèmes
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Msvcp80.dll8.0.50727.42548,86414-Oct-200506:26x 86
Msvcr80.dll8.0.50727.42626,68814-Oct-200506:26x 86
Sqldiscoveryapi.dll2005.90.1518.0527,06421-Janvier 200600:11x 86
SQL Server 2005 x 64 edition
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Msvcp80.dll8.0.50727.421,097,72814-Oct-200518:46x 64
Msvcr80.dll8.0.50727.42822,78414-Oct-200518:46x 64
Sqldiscoveryapi.dll2005.90.1518.0745,68821-Janvier 200604:14x 64
SQL Server 2005 pour les systèmes Itanium
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Msvcp80.dll8.0.50727.421,385,47214-Oct-200518:35IA-64
Msvcr80.dll8.0.50727.421,484,80014-Oct-200518:35IA-64
Sqldiscoveryapi.dll2005.90.1518.01,924,31221-Janvier 200603:30IA-64

Contournement

Pour contourner ce problème, procédez comme suit :
  1. Déterminer l'instruction INSERT posant problème qui provoque la violation d'accès.
  2. Forcer l'optimiseur de requête pour générer un plan de série de l'instruction INSERT problématique. Par conséquent, l'instruction peut être exécutée sur un thread.
note Si vous ne pouvez pas déterminer l'instruction INSERT posant problème qui provoque la violation d'accès, vous pouvez utiliser la méthode décrite dans la méthode 3 pour contourner ce problème.

Pour déterminer l'instruction INSERT posant problème qui provoque la violation d'accès, procédez comme suit :
  1. Dans le fichier journal des erreurs de SQL Server, recherchez le message d'erreur de violation d'accès.
  2. En haut de la message d'erreur de violation d'accès, recherchez les informations du tampon d'entrée.
  3. Recherchez les informations de lot qui suivent les informations du tampon d'entrée.

    note Le lot contient l'instruction INSERT posant problème qui provoque la violation d'accès.
  4. Si le lot ne contient qu'une seule instruction INSERT, cette affirmation est exactement l'instruction INSERT problématique. Si le lot contient plusieurs instructions INSERT, effectuer les opérations suivantes pour déterminer l'instruction INSERT posant problème :
    1. Dans SQL Server Profiler, créer un suivi par rapport à l'instance de SQL Server 2005.
    2. Dans la catégorie d'événement erreurs et avertissements , sélectionnez la classe d'événements attention et la classe d'événements exception .

      note Vous pouvez utiliser ces classes d'événements pour déterminer la dernière instruction commence à exécuter avant de la violation d'accès.

      Si le lot contient uniquement des instructions Transact-SQL, sélectionnez les classes d'événements supplémentaires suivantes sous la catégorie d'événement TSQL :
      • SQL:BatchStarting
      • SQL:BatchCompleted
      • SQL:StmtStarting
      • SQL:StmtCompleted
      Si le lot contient une procédure stockée à laquelle la violation d'accès se produit, sélectionnez les classes d'événements supplémentaires suivantes sous la catégorie d'événement procédures stockées :
      • SP: début
      • SP: terminé
      • SP: StmtStarting
      • SP:StmtCompleted
    3. Exécuter le même lot à partir de l'application cliente.

      Vous devez suivre cette étape pour reproduire la violation d'accès. Ensuite, vous pouvez déterminer l'instruction INSERT problématique. Lorsque vous exécutez le lot, assurez-vous que le suivi est en cours d'exécution.

      Si l'application cliente n'est pas SQL Server Management Studio, vous pouvez également manuellement exécuter le même lot dans SQL Server Management Studio. Toutefois, vous ne pouvez pas obtenir le même plan d'exécution comme le plan de l'exécution d'origine qui provoque le problème. Ce problème se produit si SQL Server 2005 recompiles l'instruction INSERT posant problème dans le lot en utilisant un plan d'exécution différentes ou avec différents paramètres.
    4. Arrêter le suivi et puis analyser les résultats de suivi pour déterminer l'instruction INSERT problématique. Pour déterminer l'instruction INSERT problématique, déterminer le SPID qui rencontre la violation d'accès et qui déconnecte l'application cliente. Puis, sur le SPID, Notez l'instruction INSERT qui satisfait aux exigences suivantes :
      • L'instruction INSERT est démarrée.
      • L'instruction INSERT même n'est pas terminée.
Pour forcer l'optimiseur de requête pour générer un plan de série de l'instruction INSERT posant problème, utilisez une des méthodes suivantes.

Méthode 1

note Utilisez cette méthode si vous pouvez accéder à l'instruction INSERT problématique.

Ajouter l'expression OPTION (MAXDOP 1) à l'instruction INSERT problématique. Voici un exemple de la nouvelle instruction INSERT.
INSERT INTO MyTable (Col1, Col2)
SELECT Col1, Col2 FROM OtherTable
OPTION (MAXDOP 1) 
Pour plus d'informations sur l'indicateur de requête MAXDOP, reportez-vous à la section « MAXDOP à l'aide » sur le site Web MSDN (Microsoft Developer Network) suivante :
http://msdn2.microsoft.com/en-us/library/ms181714.aspx

Méthode 2

note Utilisez cette méthode si vous ne pouvez pas accéder à l'instruction INSERT problématique. Par exemple, l'instruction INSERT posant problème est à partir d'une application cliente. Toutefois, vous ne pouvez pas reconfigurer l'application cliente ou vous ne pouvez pas recompiler l'application cliente pour ajouter l'expression OPTION (MAXDOP 1) . Ou, l'instruction INSERT problématique dans une procédure stockée. Toutefois, la procédure stockée est chiffrée. Vous ne pouvez pas modifier les instructions dans la procédure stockée.

Utilisez la procédure sp_create_plan_guide stockées par rapport à l'instruction INSERT problématique. En procédant ainsi, vous forcez l'expression D'OPTION (MAXDOP 1) dans l'instruction INSERT problématique. Voici un exemple d'utilisation de la procédure sp_create_plan_guide stockées.
sp_create_plan_guide @name = N'planguide_for_MyFailingProc', -- Arbitrary name
@stmt = N'INSERT INTO MyOneFailingStatementTable VALUES (@a,@b,@c)', -- The problematic INSERT statement
@type = N'OBJECT', @module_or_batch = N'dbo.MyFailingProc', -- The name of the stored procedure that contains the problematic INSERT statement
@params = NULL, @hints = N'OPTION (MAXDOP 1)'-- Query hint to prevent parallelism
Pour plus d'informations sur la procédure sp_create_plan_guide stockés, reportez-vous au site Web MSDN suivant :
http://msdn2.microsoft.com/en-us/library/ms179880.aspx

Méthode 3

note Utilisez cette méthode si une des conditions suivantes est remplie :
  • L'instruction INSERT posant problème est générée dynamiquement.
  • Vous ne pouvez pas déterminer l'instruction INSERT qui provoque la violation d'accès.
important Cette méthode permet de toutes les requêtes sur l'instance de SQL Server 2005 pour s'exécuter sur un thread. Nous ne suggère pas d'utiliser cette méthode. Cette méthode peut provoquer des problèmes performances sur les requêtes de s'exécuter sur l'instance.

Exécutez les instructions Transact-SQL suivantes.
sp_configure 'show advanced options', 1;
GO

RECONFIGURE WITH OVERRIDE;
GO

sp_configure 'max degree of parallelism', 1;
GO

RECONFIGURE WITH OVERRIDE;
GO
Pour plus d'informations sur l'option degré maximum de parallélisme , reportez-vous au site Web MSDN suivant :
http://msdn2.microsoft.com/en-us/library/ms181007.aspx

Statut

Microsoft a confirmé que c'est un problème dans les produits Microsoft répertoriés dans la section « S'applique à ».

Plus d'informations

Pour plus d'informations sur le schéma d'appellation des mises à jour SQL Server, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
822499 Nouveau modèle d'affectation de noms pour les packages de correctifs logiciels Microsoft SQL Server
Pour plus d'informations sur la terminologie mise à jour logicielles, 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

Propriétés

Numéro d'article: 912885 - Dernière mise à jour: mardi 20 novembre 2007 - Version: 3.5
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft SQL Server 2005 Enterprise Edition
  • Microsoft SQL Server 2005 Enterprise X64 Edition
  • Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Standard X64 Edition
  • Microsoft SQL Server 2005 Standard Edition for Itanium-based Systems Community Technology Preview
Mots-clés : 
kbmt kbautohotfix kbsql2005engine kbsql2005presp1fix kbhotfixserver kbfix kbbug kbsqlserv2005fix kbqfe kbpubtypekc KB912885 KbMtfr
Traduction automatique
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: 912885
L'INFORMATION CONTENUE DANS CE DOCUMENT EST FOURNIE PAR MICROSOFT SANS GARANTIE D'AUCUNE SORTE, EXPLICITE OU IMPLICITE. L'UTILISATEUR ASSUME LE RISQUE DE L'UTILISATION DU CONTENU DE CE DOCUMENT. CE DOCUMENT NE PEUT ETRE REVENDU OU CEDE EN ECHANGE D'UN QUELCONQUE PROFIT.

Envoyer des commentaires

 

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