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

SQL Oracle Discussion :

Comment éliminer des lignes d'un group by Rollup ?


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2011
    Messages
    60
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Septembre 2011
    Messages : 60
    Par défaut Comment éliminer des lignes d'un group by Rollup ?
    Bonjour à tous,

    Bon je ne suis pas sur que mon titre soit très claire !

    Si j'ai bien compris ce que j'ai pu lire sur le net, il est possible de détecter des requêtes "optimisables" avec des bind variables, en regroupant les SQL HASH VALUE et SQL_ID.

    J'aimerai donc ne conserver que les lignes dont le couple SQL_HASH_VALUE et SQL_ID est différent pour une même valeur de SQL_HASH_VALUE. (pas sûr d'être très claire une fois de plus ) Cela me permettrait d'avoir le SQL_ID des requêtes à vérifier.

    Voici ma requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT DECODE(
              GROUPING(sql_id), 1, 'TOTAL', ' ') "TOTAL",
            sql_plan_hash_value, sql_id,  COUNT(sql_id)
    FROM TABLE
    WHERE sql_id IS NOT NULL AND sql_plan_hash_value IS NOT NULL AND ROWNUM <10000
    GROUP BY ROLLUP(sql_plan_hash_value, sql_id)
    HAVING sql_plan_hash_value <> 0 
    ORDER BY 2, 3 ;
    Merci d'avance pour vos suggestions

  2. #2
    Membre Expert Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Par défaut
    Salut !

    Pour le coup, ça se résume pas juste à "j'ai plusieurs lignes pour le même plan" ?

    Du coup, having count(*) > 1 devrait suffire, non ?

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2011
    Messages
    60
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Septembre 2011
    Messages : 60
    Par défaut
    Salut pacmann,

    Non, j'ai déjà essayé. Je ne sais pas ce qu'il compte mais il me renvoie toujours des lignes où je n'ai qu'une ligne avec un couple SQL_HASH/SQL_ID et une ligne pour le total.
    (Avec la condition HAVING count(*) > 2)

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Quelque chose comme ça devrait fonctionner :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
      SELECT "TOTAL"
           , sql_plan_hash_value
           , sql_id
           , nb_sql_id
        FROM
    (
      SELECT DECODE(GROUPING(sql_id), 1, 'TOTAL', ' ') as "TOTAL"
           , sql_plan_hash_value
           , sql_id
           , COUNT(sql_id) as nb_sql_id
           , count(sql_id) over(partition by sql_plan_hash_value) as cdi
        FROM SYS.V_$SQL_PLAN_MONITOR
       WHERE sql_id IS NOT NULL
         AND sql_plan_hash_value IS NOT NULL
         AND ROWNUM < 10000
    GROUP BY ROLLUP(sql_plan_hash_value, sql_id)
      HAVING sql_plan_hash_value <> 0
    )
       WHERE cdi > 1
    ORDER BY 2, 3;

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

Discussions similaires

  1. [WD-2003] Comment éliminer des lignes inutiles avant un tableau
    Par CSR94 dans le forum VBA Word
    Réponses: 6
    Dernier message: 04/11/2010, 10h05
  2. Réponses: 5
    Dernier message: 11/08/2008, 16h25
  3. [Requete] Comment ignorer des lignes avec un LOAD DATA
    Par frangin2003 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 09/11/2005, 13h14
  4. Comment mettre des lignes de couleur dans une TCheckListBox ?
    Par Isa31 dans le forum Composants VCL
    Réponses: 9
    Dernier message: 31/03/2005, 09h40
  5. Réponses: 4
    Dernier message: 02/09/2004, 15h50

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