CORRECTIF : performances système peut être lent lorsqu'une application envoie plusieurs requêtes sur une base de données SQL Server 2005 qui utilise le paramétrage simple

Traductions disponibles Traductions disponibles
Numéro d'article: 920206 - Voir les produits auxquels s'applique cet article
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 ce 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

Envisagez le scénario suivant : une application envoie plusieurs requêtes sur une base de données Microsoft SQL Server 2005. Les requêtes de texte de requête identique et déclarer les mêmes paramètres. Cependant, les requêtes a également comporter différentes combinaisons de précision et l'échelle pour les valeurs du type de données numérique dans la chaîne de déclaration de paramètre. La base de données SQL Server 2005 utilise paramétrage simple. Dans ce scénario, les performances du système SQL Server 2005 peuvent être lent. En outre, vous pouvez rencontrer une utilisation élevée du processeur.

Ce problème se produit plus fréquemment lorsque la base de données SQL Server 2005 est importante et est dans un scénario de stress haute.

note Le comportement par défaut d'une base de données SQL Server 2005 consiste à utiliser paramétrage simple.

Cause

Ce problème se produit car SQL Server doit examiner plusieurs requêtes pour rechercher la requête une qui existe une correspondance le texte de la requête, les paramètres et la chaîne de déclaration de paramètre.

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

Pour appliquer ce correctif, vous faut SQL Server 2005 Service Pack 1 (SP1) installé sur l'ordinateur.
Pour plus d'informations sur la façon d'obtenir SQL Server 2005 Service Pack 1, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
913089 Comment obtenir le dernier pack service pour SQL Server 2005

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 sur le remplacement de correctif

Ce correctif ne remplace aucun autre correctif.

Informations sur le fichier de correctif

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 de 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.
correctif logiciel SQL Server 2005, 32 bits
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.075,55214-Juin 200620:29x 86
Microsoft.SqlServer.SqlEnum.dll9.0.2164.0908,06414-Juin 200620:32x 86
Msgprox.dll2005.90.2164.0197,92014-Juin 200620:29x 86
Msmdlocal.dll9.0.2164.015,661,85614-Juin 200620:33x 86
Mssqlsystemresource.ldfNon applicable524,28814-Juin 200614:23Non applicable
Mssqlsystemresource.mdfNon applicable39,911,42414-Juin 200614:23Non applicable
Replprov.dll2005.90.2164.0547,61614-Juin 200620:31x 86
Replrec.dll2005.90.2164.0782,11214-Juin 200620:32x 86
Sqlaccess.dll2005.90.2164.0347,93614-Juin 200620:31x 86
Sqlservr.exe2005.90.2164.028,950,87214-Juin 200620:33x 86
correctif logiciel SQL Server 2005, 64 bits
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.075,55214-Juin 200620:29x 86
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.091,42414-Juin 200621:10x 64
Microsoft.SqlServer.SqlEnum.dll9.0.2164.0875,29614-Juin 200621:12x 86
Msgprox.dll2005.90.2164.0259,36014-Juin 200621:10x 64
Msmdlocal.dll9.0.2164.015,661,85614-Juin 200620:33x 86
Mssqlsystemresource.ldfNon applicable524,28814-Juin 200614:23Non applicable
Mssqlsystemresource.mdfNon applicable39,911,42414-Juin 200614:23Non applicable
Replprov.dll2005.90.2164.0745,24814-Juin 200621:12x 64
Replrec.dll2005.90.2164.01,008,41614-Juin 200621:12x 64
Sqlaccess.dll2005.90.2164.0355,10414-Juin 200621:11x 86
Sqlservr.exe2005.90.2164.039,251,23214-Juin 200621:13x 64
correctif logiciel SQL Server 2005, 64 bits pour les processeurs Itanium
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.0163,10414-Juin 200620:29IA-64
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.075,55214-Juin 200620:29x 86
Microsoft.SqlServer.SqlEnum.dll9.0.2164.0875,29614-Juin 200620:29x 86
Msgprox.dll2005.90.2164.0542,49614-Juin 200620:28IA-64
Msmdlocal.dll9.0.2164.048,733,98414-Juin 200620:30IA-64
Mssqlsystemresource.ldfNon applicable524,28814-Juin 200614:23Non applicable
Mssqlsystemresource.mdfNon applicable39,911,42414-Juin 200614:23Non applicable
Replprov.dll2005.90.2164.01,617,18414-Juin 200620:29IA-64
Replrec.dll2005.90.2164.02,141,47214-Juin 200620:29IA-64
Sqlaccess.dll2005.90.2164.0349,47214-Juin 200620:28x 86
Sqlservr.exe2005.90.2164.072,208,67214-Juin 200620:30IA-64

Statut

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

Contournement

Pour contourner ce problème, utilisez paramétrage explicite dans l'application cliente. Lorsque vous utilisez paramétrage explicite dans l'application cliente, plan d'exécution seule est créé et stocké dans le cache de procédure. Dans cette solution de contournement, les performances du système SQL Server 2005 s'exécute comme prévu.

Pour plus d'informations sur Paramétrage explicite et plan d'exécution réutiliser, reportez-vous au site de Web MSDN (Microsoft Developer Network) suivant adresse :
http://msdn2.microsoft.com/en-us/library/ms175580.aspx

Plus d'informations

Lorsqu'une application envoie plusieurs requêtes sur une base de données SQL Server 2005, le plan d'exécution pour chaque requête doit être présent dans le cache de procédure avant l'exécution de la requête.

note Si le plan d'exécution d'une requête spécifique n'est pas présent dans le cache de procédure, SQL Server compile la requête, écrit le plan d'exécution de la requête dans le cache de procédure et puis exécute la requête.

Lorsque SQL Server 2005 extrait un plan d'exécution mis en cache d'une requête spécifique à partir du cache de procédure, SQL Server identifie le plan d'exécution correspondant en utilisant une clé de hachage était dérivée lorsque la requête a été compilée. La version d'origine de SQL Server 2005 dérive de clés de hachage d'uniquement le texte de la requête et ignore la chaîne de déclaration de paramètre. Lorsque SQL Server 2005 dérivée de clés de hachage uniquement le texte de la requête, SQL Server 2005 met les clés de hachage pour toutes les requêtes qui ont texte de la même requête et les mêmes paramètres dans le même paquet de hachage. Ce problème se produit même si chaque requête comporte une combinaison différente de précision et d'échelle pour les valeurs numériques dans la chaîne de déclaration de paramètre. Lorsque SQL Server 2005 tente d'extraire un plan d'exécution requête mis en cache le cache de procédure d'une requête spécifique, SQL Server doit examiner tous les les requête plans d'exécution dans le paquet de hachage correspondant pour rechercher le plan d'exécution une requête qui correspond au texte de la requête, les paramètres et la chaîne de déclaration de paramètre.

Après avoir appliqué ce correctif, SQL Server 2005 dérivée clés de hachage le texte de la requête et la chaîne de déclaration de paramètre. Lorsqu'une nouvelle requête est une combinaison de précision et d'échelle pour les valeurs numériques dans la chaîne déclaration de paramètre qui ne correspond pas à une autre requête existante, SQL Server 2005 met la clé de hachage pour la nouvelle requête dans un nouveau paquet de hachage. SQL Server 2005 met la clé de hachage pour la nouvelle requête dans un nouveau paquet de hachage même lorsque la nouvelle requête a texte de la même requête et les paramètres mêmes sous une autre requête existante. Par conséquent, lorsque SQL Server 2005 tente d'extraire les plans d'exécution mis en cache le cache de procédure pour la nouvelle requête, le paquet de hachage correspondante contient uniquement une requête pour SQL Server à examiner.

Dans ce scénario résolution correctif, SQL Server 2005 comporte toujours plusieurs plans d'exécution. Ce problème se produit car un plan d'exécution distinct est créé pour chaque requête qui possède une nouvelle combinaison de précision et l'échelle pour les valeurs numériques dans la chaîne de déclaration de paramètre. Chaque plan d'exécution nécessite des ressources de système SQL Server 2005 pour créer le plan d'exécution. Chaque plan d'exécution nécessite des ressources de système SQL Server 2005 pour stocker le plan d'exécution dans le cache de procédure. Étant donné que le scénario de solution correctif nécessite beaucoup de ressources système SQL Server 2005, SQL Server 2005 système performances peuvent toujours être plus lentes que prévu.
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

Propriétés

Numéro d'article: 920206 - Dernière mise à jour: mardi 20 novembre 2007 - Version: 1.8
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Standard X64 Edition
  • Microsoft SQL Server 2005 Standard Edition for Itanium Based Systems
  • 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
Mots-clés : 
kbmt kbautohotfix kbbug kbfix kbtshoot kbhotfixserver kbqfe kbpubtypekc KB920206 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: 920206
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