CORRIGER : Des résultats incorrects ou violation de contrainte lorsque vous exécutez une instruction SELECT ou DML qui utilise la fonction row_number et un plan d'exécution parallèle dans SQL Server 2008

Traductions disponibles Traductions disponibles
Numéro d'article: 2589980 - Voir les produits auxquels s'applique cet article
Agrandir tout | Réduire tout
Microsoft distribue les correctifs de Microsoft SQL Server 2008 en tant que fichier téléchargeable. Étant donné que les correctifs sont cumulatifs, chaque nouvelle version contient tous les correctifs et des correctifs de sécurité fournis avec la précédente 2008 de SQL Server version du correctif.

Symptômes

Considérez le scénario suivant :
  • Vous exécutez une requête parallèle qui utilise le ROW_NUMBER fonction de Microsoft SQL Server 2008.
  • Vous essayez d'exécuter la requête en utilisant une sous-requête qui se trouve dans un SÉLECTIONNEZ instruction ou une instruction de langage de Manipulation de données (DML).
Dans ce scénario, vous rencontrez l'un des problèmes suivants :
  • Vous recevez des résultats incorrects si vous exécutez la requête à l'intérieur de laSÉLECTIONNEZ instruction autant de fois.
  • La table peut contenir des données incorrectes si la requête est exécutée à l'intérieur d'une instruction DML. Si la table comporte des contraintes, l'instruction peut échouer avec une violation de contrainte.

    Par exemple, un INSÉRER instruction peut échouer et une erreur de violation de clé primaire se produit si la table possède une clé primaire.


Remarque Ces problèmes peuvent se produire dans une des situations suivantes :
  • Vous définissez le MAXDOP option d'indicateur de requête à une valeur supérieure à 2.
  • Vous définissez le Max Degree of Parallelism option avec une valeur supérieure à 2 dans la configuration du serveur.

Résolution

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

968382 Comment faire pour obtenir le dernier service pack pour SQL Server 2008

Contournement

Pour contourner ce problème, appliquez l'une des méthodes suivantes :
  • Activer l'indicateur de trace 4134 si vous avez appliqué une des mises à jour suivantes :
    • Package de mise à jour cumulative 6 pour SQL Server 2008 ou d'un package de mise à jour cumulative d'ultérieurement pour SQL Server 2008
    • Le package de mise à jour cumulative 2 pour SQL Server 2008 Service Pack 1 (SP1) ou un ultérieurement mise à jour cumulative pour SQL Server 2008 SP1


    Pour plus d'informations sur l'activation des indicateurs de trace, reportez-vous au site Web MSDN suivant :
    Comment faire pour activer les indicateurs de trace
  • Faire référence à la section « Contournement » dans l'article de la Base de connaissances Microsoft 970198.

    Pour plus d'informations, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
    970198 CORRIGER : Vous recevez un résultat incorrect lorsque vous exécutez une requête qui utilise la fonction row_number dans SQL Server 2008

Propriétés

Numéro d'article: 2589980 - Dernière mise à jour: lundi 22 août 2011 - Version: 1.0
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Enterprise Evaluation
  • Microsoft SQL Server 2008 Express
  • Microsoft SQL Server 2008 Express with Advanced Services
  • Microsoft SQL Server 2008 Service Pack 1
  • Microsoft SQL Server 2008 Service Pack 2
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Standard Edition for Small Business
  • Microsoft SQL Server 2008 Web
  • Microsoft SQL Server 2008 Workgroup
Mots-clés : 
kbqfe kbfix kbexpertiseadvanced kbsurveynew kbmt KB2589980 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: 2589980
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