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 :

Calcul des histogrammes [11gR2]


Sujet :

Administration Oracle

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 28
    Points : 22
    Points
    22
    Par défaut Calcul des histogrammes
    Bonjour,

    Travaillant sur une base Oracle 11.2, j'ai actuellement le temps d'exécution d'une requête dégradé du fait qu'un histogramme n'est pas calculé sur une colonne d'une table interrogé par la requête.

    Le mode de calcul utilisé par défaut est FOR ALL COLUMNS SIZE AUTO.

    Je me suis rendu compte qu'en enlevant la clause SIZE AUTO, l'histogramme relatif à ma colonne était de nouveau calculé et le coût relatif au plan d'exécution nettement amélioré.

    Je me pose donc la question de savoir quelle est la différence entre le mode de calcul FOR ALL COLUMNS SIZE AUTO et FOR ALL COLUMNS. Quels impacts peut-il y a voir d'utiliser le FOR ALL COLUMNS ?

    D'avance merci.

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 28
    Points : 22
    Points
    22
    Par défaut
    J'ai déjà lu le contenu du lien, mais il ne répond pas à la question posé.

    Il mentionne juste que la clause SIZE est relatif à la création d'histogramme et décrit les options possibles.

    Si je ne renseigne pas cette clause, Oracle me calcule tout de même les histogrammes, mais de manière différente qu'avec la clause SIZE AUTO.

    Ainsi, si l'on ne spécifie pas la clause SIZE, avec quelle méthode calcule-t-il les histogrammes et quels peuvent être les impacts ?

  4. #4
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    Le paramètre auto c'est la base (il en faut bien une) mais cette base n'est pas appropriée à tous les cas de figures.
    Vous pouvez donc affiner cette base en jouant sur le paramètre method_opt et déterminer le calcul des histogrammes pour les colonnes nécessaires.

    Tiré du lien ci-dessus :
    In this case we wanted all of the columns in the table to have base statistics so we should use FOR ALL COLUMNS. But what about the SIZE part of the parameter? We only want a histogram on one column, so for this leading edge of the parameter setting we need to specify SIZE 1 to prevent a histogram from being created on any column.

    The second part of the parameter setting needs to specify that a histogram is needed on the CUST_ID column. This is achieved using an additional part of the METHOD_OPT syntax that we haven’t mentioned yet, called FOR COLUMNS.
    Je pense que vous êtes dans cette situation, enfin vous avez peut être besoin d'autres histogrammes mais certainement pas sur toutes les colonnes.

  5. #5
    Membre éclairé 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 : 55
    Localisation : Suisse

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

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

    Il est préférable d'utiliser cette méthode dans un premier temps:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    BEGIN
      DBMS_STATS.GATHER_TABLE_STATS ( 
        OWNNAME    => user, 
        TABNAME    => 'Table', 
        METHOD_OPT => 'FOR ALL COLUMNS SIZE SKEWONLY' );
    END;/
    ou en spécifiant directement la colonne et le nombre de buckets souhaité:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    BEGIN
      DBMS_STATS.GATHER_TABLE_STATS ( 
        OWNNAME    => user, 
        TABNAME    => 'table', 
        METHOD_OPT => 'FOR COLUMNS SIZE count  colonne' );
    END;
    /
    jko
    OCM 11g, RAC and Performance & Tuning Expert 11g
    RMAN Backup & Recovery, Data Guard and Grid Control

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 28
    Points : 22
    Points
    22
    Par défaut
    L'option SIZE ne résout pas mon problème, quelque soit le mode (SKEWONLY, REPEAT ou AUTO).

    Je pense que je vais uniquement recalculer les stats sur la colonne qui me pose problème sans pour autant spécifier le nombre de groupe (num_buckets)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    BEGIN
      DBMS_STATS.GATHER_TABLE_STATS ( 
        OWNNAME    => user, 
        TABNAME    => 'table', 
        METHOD_OPT => 'FOR COLUMNS colonne' );
    END;
    En tout cas, merci pour vos réponses

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Calcul des histogrammes avec opencv et java
    Par ekica dans le forum OpenCV
    Réponses: 1
    Dernier message: 29/06/2013, 10h30
  2. [DBA] Calcul des Statistiques sans privilèges DBA
    Par Krashtest dans le forum Administration
    Réponses: 14
    Dernier message: 06/05/2004, 16h08
  3. calculs des points
    Par rabi dans le forum OpenGL
    Réponses: 11
    Dernier message: 12/02/2004, 10h03
  4. Calcul des jours feriés
    Par obione dans le forum Langage
    Réponses: 5
    Dernier message: 07/11/2003, 12h36
  5. Calcul des numéros de semaine d'un calendrier
    Par Invité dans le forum Algorithmes et structures de données
    Réponses: 4
    Dernier message: 06/11/2002, 21h29

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