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

Administration Oracle Discussion :

Utilisation du paramètre OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES


Sujet :

Administration Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Janvier 2009
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 55
    Par défaut Utilisation du paramètre OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES
    Bonjour,

    Je voulais avoir de retours sur l'utilisation des SQL Plan Baselines.

    Surtout si qqn a activé le paramètre (OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES) dans un environnement de production.

    Ce qui m'interesse n'est pas la doc Oracle (que j'ai lu bien sur ) mais surtout des retours d’expérience sur l'utilité de cette option et la gestion des plans d’exécution sachant qu'il faut accepter les nouveaux plans d’exécutions de façon explicite.

    Cordialement,

  2. #2
    Membre averti
    Inscrit en
    Janvier 2009
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 55
    Par défaut
    Un ptit up.
    Je vois que personne na répondu ce qui renforce l'idée que cette fonctionnalité n'est pas très utilisé. Voila un ptit topo la dessus:
    Terminologie:
    SQL plan management est une méthode de sauvegarde des plans d’exécution.
    SQL plan baseline est un ensemble de plans d’exécutions acceptés pour une requête SQL qui sont reconnus comme étant efficaces.
    SQL Plan history représente l’ensemble des plans d’exécutions pour une requête SQL, ceux qui sont acceptés et ceux qui ne sont pas acceptés.

    La gestion des plans s’active avec le paramètre OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES à TRUE (par default il est FALSE).

    Fonctionnement :
    Une fois le paramètre activé pour chaque requête SQL Oracle cherche le meilleur plan d’exécution :
    Si il n’y a aucun plan dans d’exécution dans SQL Plan history alors il génère le premier plan et il l’introduit dans SQL Plan history et il le marque comme accepté.
    S’il y un plan accepté dans SQL Plan history et si le plan généré couramment est différent de celui-ci il sauvegarde le nouveau plan dans SQL Plan history, il le marque comme non accepté et il utilise celui qui est accepté.

    Pour être utilisé un plan qui est dans SQL Plan history DBA doit accepté par le DBA (même si les objets afférents ont changés ex rajout d’un index).
    Plusieurs plan d’exécutions peuvent être acceptés dans SQL Plan history.
    CBO choisira toujours celui qui a le cout moindre parmi les plans acceptés.

    Je vais lui donner une chance en qualif. Si j'oublie pas je reviens sur ce poste.

    Cdt,

  3. #3
    Membre émérite Avatar de jkofr
    Homme Profil pro
    Senior Consultant DBA (Trivadis SA)
    Inscrit en
    Octobre 2006
    Messages
    484
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : Suisse

    Informations professionnelles :
    Activité : Senior Consultant DBA (Trivadis SA)
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 484
    Par défaut
    Hello,

    Les changements de plan sont automatiquements vérifiés par l’optimiseur pendant les maintenance tasks.

    Il est possible de ne pas activer OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES et de manuellement importer des plans via le package DBMS_SPM fonctions load_plan_from_cursor_cache et load_plan_from_sql_set.

    A partir de SQL tuning advisor, tu peux ajouter de nouveaux plans a ta baseline.

    Un petit resumé http://www.databasejournal.com/featu...tabase-11g.htm
    Jko

  4. #4
    Membre averti
    Inscrit en
    Janvier 2009
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 55
    Par défaut
    Merci de ton passage.

    Par default OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES est a false donc la capture des plans est désactivé.

    Donc par default pas de plans capturés. Oracle utilise simplement le plan généré au coup par coup sans se poser de questions.

    Ce qui m'inquette est le fait d'avoir valider systématiquement les plans une fois OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES mise a TRUE.

    Comment tu gere ca ? Ou tu a mis simplement en acceptation automatique ? C'est pas un peux risqué ?

  5. #5
    Membre émérite Avatar de jkofr
    Homme Profil pro
    Senior Consultant DBA (Trivadis SA)
    Inscrit en
    Octobre 2006
    Messages
    484
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : Suisse

    Informations professionnelles :
    Activité : Senior Consultant DBA (Trivadis SA)
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 484
    Par défaut
    L'optimiseur contrôle automatiquement que le nouveau plan ne dégrade pas les performances.
    Dans ce cas il est valide et accepte.

    Tu peux accepter ou fixer un plan manuellement avec la fonction EVOLVE_SQL_PLAN_BASELINE.

    Jko

Discussions similaires

  1. Utilisation du paramètre *Sender
    Par olivier4020 dans le forum C++Builder
    Réponses: 5
    Dernier message: 21/12/2006, 09h22
  2. Utilisation des paramètres avec rowsource - 97 et 2003
    Par IntenseM3 dans le forum Access
    Réponses: 1
    Dernier message: 10/05/2006, 09h18
  3. Réponses: 2
    Dernier message: 21/09/2005, 17h23
  4. problème d'utilisation de paramètre
    Par pelelive dans le forum Access
    Réponses: 2
    Dernier message: 22/06/2005, 14h55
  5. [XSLT] Utilisation de paramètre
    Par stailer dans le forum Format d'échange (XML, JSON...)
    Réponses: 4
    Dernier message: 10/05/2004, 14h49

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