IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

MS SQL Server Discussion :

Plans d'execution sp_executesql


Sujet :

MS SQL Server

  1. #1
    Membre expérimenté
    Avatar de SQL_EVAN
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juillet 2011
    Messages
    161
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Thaïlande

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Conseil

    Informations forums :
    Inscription : Juillet 2011
    Messages : 161
    Par défaut Plans d'execution sp_executesql
    Salut tout le monde! J'etais hors radar depuis un bon moment a cause d'une mutation a l'etranger (ceci explique le manque d'accents dans mon texte, plus de claviers azerty )

    Je suis de retour avec une question qui m'embete :

    De quelle facon SQL Server gere les requetes sp_executesql au niveau des plans d'execution?

    Je sais que theoretiquement le moteur stocke des plans d'execution logiques et adapte quand on met les predicats en parametre

    ex.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    --requete simple
    SELECT *
    FROM PERSONS 
    WHERE NAME = 'Toto'
     
    -- requete avec plan d'execution optimiser sur l'indexe de noms
    DECLARE @name VARCHAR(255)
    SET @name = 'Toto'
     
    SELECT *
    FROM PERSONS
    WHERE NAME = @name
    Ceci me parait clair et logique que le moteur prepare un plan d'execution garder en memoire optimise pour un predicat en parametre.

    Par contre si on passe pare sp_executesql on passe pare une procedure stockee et donc ca ne me parait pas clair comment le moteur puisse calculer un plan d'execution optimiser sur les indexes des tables dans l'SQL dynamique... pouvez vous me donner plus d'infos a ce sujet s'il vous plait?

  2. #2
    Membre émérite
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2009
    Messages
    623
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Août 2009
    Messages : 623
    Par défaut
    A mon avis, le sql dynamique a son plan d'exécution recalculé à chaque fois. Mais je pense que l'optimiseur est capable de le conserver avec le sp_executesql si seulement les paramètres changent.

  3. #3
    Membre émérite
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2009
    Messages
    623
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Août 2009
    Messages : 623
    Par défaut
    La procédure sp_executesql peut être utilisée à la place de procédures stockées afin d'exécuter une instruction Transact-SQL plusieurs fois lorsque la modification des valeurs de paramètres de l'instruction constitue l'unique changement. L'instruction Transact-SQL même demeurant constante, seules les valeurs de paramètre changent. Par conséquent, l'optimiseur de requête de SQL Server peut réutiliser le plan d'exécution généré pour la première exécution.
    http://msdn.microsoft.com/fr-fr/library/ms188001.aspx

Discussions similaires

  1. Quand change le plan d'execution?
    Par kervoaz dans le forum Administration
    Réponses: 17
    Dernier message: 03/12/2007, 10h45
  2. Bind variables et plan d'execution
    Par Wurlitzer dans le forum Oracle
    Réponses: 6
    Dernier message: 26/02/2007, 14h04
  3. [Oracle 10.2] Plan d'execution fonction PL/SQL
    Par pegase06 dans le forum PL/SQL
    Réponses: 6
    Dernier message: 13/02/2007, 12h02
  4. Plans d'execution differents
    Par jajaCode dans le forum Oracle
    Réponses: 13
    Dernier message: 14/12/2006, 12h29
  5. plan d'execution
    Par osoudee dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 09/03/2006, 10h40

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo