Dans Microsoft SQL Server, comment puis-je obtenir un plan d'exécution de requête pour une requête / procédure stockée?
338
Dans Microsoft SQL Server, comment puis-je obtenir un plan d'exécution de requête pour une requête / procédure stockée?
Réponses:
Il existe un certain nombre de méthodes pour obtenir un plan d'exécution, laquelle à utiliser dépendra de votre situation. Habituellement, vous pouvez utiliser SQL Server Management Studio pour obtenir un plan, mais si, pour une raison quelconque, vous ne pouvez pas exécuter votre requête dans SQL Server Management Studio, il peut être utile de pouvoir obtenir un plan via SQL Server Profiler ou en inspectant le cache du plan.
Méthode 1 - Utilisation de SQL Server Management Studio
SQL Server est livré avec quelques fonctionnalités intéressantes qui facilitent la capture d'un plan d'exécution, assurez-vous simplement que l'élément de menu "Inclure le plan d'exécution réel" (situé sous le menu "Requête") est coché et exécutez votre requête normalement .
Si vous essayez d'obtenir le plan d'exécution des instructions dans une procédure stockée, vous devez exécuter la procédure stockée, comme suit:
Une fois votre requête terminée, un onglet supplémentaire intitulé "Plan d'exécution" devrait apparaître dans le volet des résultats. Si vous avez exécuté plusieurs instructions, vous pouvez voir de nombreux plans affichés dans cet onglet.
De là, vous pouvez inspecter le plan d'exécution dans SQL Server Management Studio, ou cliquer avec le bouton droit sur le plan et sélectionner "Enregistrer le plan d'exécution sous ..." pour enregistrer le plan dans un fichier au format XML.
Méthode 2 - Utilisation des options SHOWPLAN
Cette méthode est très similaire à la méthode 1 (en fait, c'est ce que fait SQL Server Management Studio en interne), mais je l'ai incluse pour être complet ou si vous n'avez pas SQL Server Management Studio disponible.
Avant d'exécuter votre requête, exécutez l' une des instructions suivantes. L'instruction doit être la seule instruction du lot, c'est-à-dire que vous ne pouvez pas exécuter une autre instruction en même temps:
Ce sont des options de connexion et vous n'avez donc besoin de l'exécuter qu'une seule fois par connexion. À partir de ce moment, toutes les instructions exécutées seront accompagnées d'un jeu de résultats supplémentaire contenant votre plan d'exécution au format souhaité - exécutez simplement votre requête comme vous le feriez normalement pour voir le plan.
Une fois que vous avez terminé, vous pouvez désactiver cette option avec l'instruction suivante:
Comparaison des formats de plan d'exécution
Sauf si vous avez une forte préférence, ma recommandation est d'utiliser l'
STATISTICS XML
option. Cette option est équivalente à l'option «Inclure le plan d'exécution réel» dans SQL Server Management Studio et fournit le plus d'informations dans le format le plus pratique.SHOWPLAN_TEXT
- Affiche un plan d'exécution estimé basé sur du texte de base, sans exécuter la requêteSHOWPLAN_ALL
- Affiche un plan d'exécution estimé basé sur du texte avec des estimations de coûts, sans exécuter la requêteSHOWPLAN_XML
- Affiche un plan d'exécution estimé basé sur XML avec des estimations de coûts, sans exécuter la requête. Cela équivaut à l'option "Afficher le plan d'exécution estimé ..." dans SQL Server Management Studio.STATISTICS PROFILE
- Exécute la requête et affiche un plan d'exécution réel basé sur du texte.STATISTICS XML
- Exécute la requête et affiche un plan d'exécution réel basé sur XML. Cela équivaut à l'option «Inclure le plan d'exécution réel» dans SQL Server Management Studio.Méthode 3 - Utilisation de SQL Server Profiler
Si vous ne pouvez pas exécuter votre requête directement (ou si votre requête ne s'exécute pas lentement lorsque vous l'exécutez directement - n'oubliez pas que nous voulons que le plan de la requête fonctionne mal), vous pouvez capturer un plan à l'aide d'une trace de SQL Server Profiler. L'idée est d'exécuter votre requête pendant qu'une trace qui capture l'un des événements "Showplan" est en cours d'exécution.
Notez qu'en fonction de la charge, vous pouvez utiliser cette méthode dans un environnement de production, mais vous devez évidemment faire preuve de prudence. Les mécanismes de profilage SQL Server sont conçus pour minimiser l'impact sur la base de données, mais cela ne signifie pas qu'il n'y aura aucun impact sur les performances. Vous pouvez également rencontrer des problèmes pour filtrer et identifier le plan correct dans votre trace si votre base de données est fortement utilisée. Vous devriez évidemment vérifier auprès de votre DBA pour voir s'il est content que vous le fassiez sur sa précieuse base de données!
Le plan que vous obtenez est équivalent à l'option «Inclure le plan d'exécution réel» dans SQL Server Management Studio.
Méthode 4 - Inspection du cache de requêtes
Si vous ne pouvez pas exécuter votre requête directement et que vous ne pouvez pas également capturer une trace de profileur, vous pouvez toujours obtenir un plan estimé en inspectant le cache du plan de requête SQL.
Nous inspectons le cache du plan en interrogeant les DMV SQL Server . Ce qui suit est une requête de base qui répertorie tous les plans de requête mis en cache (au format xml) avec leur texte SQL. Sur la plupart des bases de données, vous devrez également ajouter des clauses de filtrage supplémentaires pour filtrer les résultats jusqu'aux plans qui vous intéressent.
Exécutez cette requête et cliquez sur le plan XML pour ouvrir le plan dans une nouvelle fenêtre - faites un clic droit et sélectionnez "Enregistrer le plan d'exécution sous ..." pour enregistrer le plan dans un fichier au format XML.
Remarques:
Parce qu'il y a tellement de facteurs impliqués (allant du schéma de table et d'index jusqu'aux données stockées et aux statistiques de table), vous devriez toujours essayer d'obtenir un plan d'exécution à partir de la base de données qui vous intéresse (normalement celle qui connaît une performance problème).
Vous ne pouvez pas capturer un plan d'exécution pour des procédures stockées chiffrées.
Plans d'exécution "réels" vs "estimés"
Un plan d'exécution réel est celui où SQL Server exécute réellement la requête, tandis qu'un plan d'exécution estimé SQL Server détermine ce qu'il ferait sans exécuter la requête. Bien que logiquement équivalent, un plan d'exécution réel est beaucoup plus utile car il contient des détails et des statistiques supplémentaires sur ce qui s'est réellement passé lors de l'exécution de la requête. Cela est essentiel lors du diagnostic de problèmes lorsque les estimations des serveurs SQL sont désactivées (par exemple lorsque les statistiques sont obsolètes).
Comment interpréter un plan d'exécution de requête?
C'est un sujet assez digne pour un livre (gratuit) à part entière.
Voir également:
la source
SET STATISTICS XML ON
le début de la requête etSET STATISTICS XML OFF|ON
les zones environnantes que vous ne voulez pas voir apparaître dans la sortie du plan: j'ai trouvé cela utile lorsque la requête contient une itération (TANT) que vous ne voulez pas / n'avez pas besoin à voir dans le plan d'exécution (sinon il serait trop lourd et long pour SQL SERVER de l'afficher).En plus de la réponse complète déjà publiée, il est parfois utile de pouvoir accéder au plan d'exécution par programme pour extraire des informations. Un exemple de code pour cela est ci-dessous.
Exemple de
StartCapture
définitionExemple de
StopCapture
définitionla source
la source
Outre les méthodes décrites dans les réponses précédentes, vous pouvez également utiliser un visualiseur de plan d'exécution gratuit et un outil d'optimisation de requête ApexSQL Plan (que j'ai récemment rencontré).
Vous pouvez installer et intégrer ApexSQL Plan dans SQL Server Management Studio, afin que les plans d'exécution puissent être affichés directement à partir de SSMS.
Affichage des plans d'exécution estimés dans ApexSQL Plan
Affichage des plans d'exécution réels dans le plan ApexSQL
Pour afficher le plan d'exécution réel d'une requête, poursuivez à partir de la 2e étape mentionnée précédemment, mais maintenant, une fois le plan estimé affiché, cliquez sur le bouton «Réel» dans la barre de ruban principale d'ApexSQL Plan.
Une fois que vous avez cliqué sur le bouton «Réel», le plan d'exécution réel s'affiche avec un aperçu détaillé des paramètres de coût ainsi que d'autres données du plan d'exécution.
Pour plus d'informations sur l'affichage des plans d'exécution, cliquez sur ce lien .
la source
Mon outil préféré pour obtenir et analyser en profondeur les plans d'exécution des requêtes est SQL Sentry Plan Explorer . Il est beaucoup plus convivial, pratique et complet pour l'analyse détaillée et la visualisation des plans d'exécution que SSMS.
Voici un exemple de capture d'écran pour que vous ayez une idée des fonctionnalités offertes par l'outil:
Ce n'est qu'une des vues disponibles dans l'outil. Remarquez un ensemble d'onglets en bas de la fenêtre de l'application, qui vous permet d'obtenir également différents types de représentation de votre plan d'exécution et des informations supplémentaires utiles.
De plus, je n'ai remarqué aucune limitation de son édition gratuite qui empêche de l'utiliser quotidiennement ou vous oblige à acheter la version Pro à terme. Donc, si vous préférez vous en tenir à l'édition gratuite, rien ne vous en empêche.
MISE À JOUR: (Merci à Martin Smith ) Plan Explorer est maintenant gratuit! Voir http://www.sqlsentry.com/products/plan-explorer/sql-server-query-view pour plus de détails.
la source
Speaking of third-party tools
lorsque personne n'a mentionné d'outils tiers.Les plans de requête peuvent être obtenus à partir d'une session d'événements étendus via l'
query_post_execution_showplan
événement. Voici un exemple de session XEvent:Après avoir créé la session, (dans SSMS), accédez à l'Explorateur d'objets et explorez Gestion | Événements prolongés | Sessions. Cliquez avec le bouton droit sur la session "GetExecutionPlan" et démarrez-la. Faites un clic droit dessus et sélectionnez "Regarder les données en direct".
Ensuite, ouvrez une nouvelle fenêtre de requête et exécutez une ou plusieurs requêtes. En voici un pour AdventureWorks:
Après un moment ou deux, vous devriez voir des résultats dans l'onglet "GetExecutionPlan: Live Data". Cliquez sur l'un des événements query_post_execution_showplan dans la grille, puis cliquez sur l'onglet "Plan de requête" sous la grille. Il devrait ressembler à ceci:
EDIT : Le code XEvent et la capture d'écran ont été générés à partir de SQL / SSMS 2012 w / SP2. Si vous utilisez SQL 2008 / R2, vous pourrez peut- être modifier le script pour le faire fonctionner. Mais cette version n'a pas d'interface graphique, vous devez donc extraire le XML showplan, l'enregistrer en tant que fichier * .sqlplan et l'ouvrir dans SSMS. C'est lourd. XEvents n'existait pas dans SQL 2005 ou version antérieure. Donc, si vous n'êtes pas sur SQL 2012 ou version ultérieure, je suggère fortement l'une des autres réponses publiées ici.
la source
À partir de SQL Server 2016+, la fonctionnalité Query Store a été introduite pour surveiller les performances. Il donne un aperçu du choix et des performances du plan de requête. Ce n'est pas un remplacement complet de la trace ou des événements étendus, mais comme il évolue d'une version à l'autre, nous pourrions obtenir un magasin de requêtes entièrement fonctionnel dans les futures versions de SQL Server. Le flux principal de Query Store
Activation du magasin de requêtes : le magasin de requêtes fonctionne au niveau de la base de données sur le serveur.
tempdb
base de données.Collecte d'informations dans le magasin de requêtes : Nous collectons toutes les informations disponibles dans les trois magasins à l'aide du magasin de requêtes DMV (vues de gestion des données).
Magasin de plan de requête: conserver les informations du plan d'exécution et il est responsable de la capture de toutes les informations liées à la compilation des requêtes.
Runtime Stats Store: Persistant les informations de statistiques d'exécution et c'est probablement le magasin le plus fréquemment mis à jour. Ces statistiques représentent les données d'exécution des requêtes.
Query Wait Stats Store: Persistance et capture des informations sur les statistiques d'attente.
REMARQUE: Query Wait Stats Store est disponible uniquement dans SQL Server 2017+
la source
Comme avec SQL Server Management Studio (déjà expliqué), il est également possible avec Datagrip comme expliqué ici .
la source
Voici une chose importante à savoir en plus de tout ce qui a été dit auparavant.
Les plans de requête sont souvent trop complexes pour être représentés par le type de colonne XML intégré qui a une limitation de 127 niveaux d'éléments imbriqués. C'est l'une des raisons pour lesquelles sys.dm_exec_query_plan peut retourner
NULL
ou même renvoyer une erreur dans les versions antérieures de MS SQL, il est donc généralement plus sûr d'utiliser sys.dm_exec_text_query_plan à la place. Ce dernier a également une fonctionnalité bonus utile de sélectionner un plan pour une déclaration particulière plutôt que l'ensemble du lot. Voici comment vous l'utilisez pour afficher les plans des instructions en cours d'exécution:La colonne de texte du tableau résultant n'est cependant pas très pratique par rapport à une colonne XML. Pour pouvoir cliquer sur le résultat à ouvrir dans un onglet séparé sous forme de diagramme, sans avoir à enregistrer son contenu dans un fichier, vous pouvez utiliser une petite astuce (rappelez-vous que vous ne pouvez pas simplement utiliser
CAST(... AS XML)
), bien que cela ne fonctionne que pour un une seule ligne:la source
Vous pouvez également le faire via PowerShell en utilisant SET STATISTICS XML ON pour obtenir le plan réel. Je l'ai écrit pour qu'il fusionne les plans à états multiples en un seul plan;
la source
Plan d'exécution estimé
Le plan d'exécution estimé est généré par l'Optimiseur sans exécuter la requête SQL.
Afin d'obtenir le plan d'exécution estimé, vous devez activer le
SHOWPLAN_ALL
paramètre avant d'exécuter la requête.METTRE SHOWPLAN_ALL SUR
Maintenant, lors de l'exécution de la requête SQL suivante:
SQL Server générera le plan d'exécution estimé suivant:
Après avoir exécuté la requête, nous souhaitons obtenir le plan d'exécution estimé, vous devez désactiver le
SHOWPLAN_ALL
car, sinon, la session de base de données actuelle ne générera que le plan d'exécution estimé au lieu d'exécuter les requêtes SQL fournies.Plan estimé de SQL Server Management Studio
Dans l'application SQL Server Management Studio, vous pouvez facilement obtenir le plan d'exécution estimé pour n'importe quelle requête SQL en appuyant sur le
CTRL+L
raccourci clavier.Plan d'exécution réel
Le plan d'exécution SQL réel est généré par l'Optimiseur lors de l'exécution de la requête SQL. Si les statistiques du tableau de la base de données sont exactes, le plan réel ne doit pas différer de manière significative de celui estimé.
Pour obtenir le plan d'exécution réel sur SQL Server, vous devez activer les
STATISTICS IO, TIME, PROFILE
paramètres, comme illustré par la commande SQL suivante:Désormais, lors de l'exécution de la requête précédente, SQL Server va générer le plan d'exécution suivant:
Après avoir exécuté la requête, nous souhaitons obtenir le plan d'exécution réel, vous devez désactiver les
STATISTICS IO, TIME, PROFILE ON
paramètres comme celui-ci:Plan réel de SQL Server Management Studio
Dans l'application SQL Server Management Studio, vous pouvez facilement obtenir le plan d'exécution estimé pour n'importe quelle requête SQL en appuyant sur le
CTRL+M
raccourci clavier.la source
Expliquer le plan d'exécution peut être très détaillé et prend beaucoup de temps à lire, mais en résumé, si vous utilisez `` expliquer '' avant la requête, cela devrait vous donner beaucoup d'informations, y compris les parties qui ont été exécutées en premier et ainsi de suite. si vous voulez lire un peu plus de détails à ce sujet, j'ai compilé un petit blog à ce sujet qui vous indique également les bonnes références. https://medium.com/swlh/jetbrains-datagrip-explain-plan-ac406772c470
la source