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 :

Requête hiérarchique : incompréhension


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Janvier 2004
    Messages
    532
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 532
    Par défaut Requête hiérarchique : incompréhension
    Bonjour,

    J'ai une table CLIENT avec ses données

    ID IDCODE IDMGR MCODE ZONE
    1 B 1 B 8
    2 B 3 B 8
    3 B 3 B 8
    4 B 3 B 8
    5 B 4 B 8

    et ce que je souhaiterais
    c'est quand je passe un client à la requête(pour une zone) je ramène tous ses manager(mgr)
    je remonte la hiérarchie.

    ex : si je prend le client 5 B alors je dois ramener son mgr c'est à dire 4 B.
    Comme 4 B a pour mgr 3 B , je dois alors aussi ramener 3 B
    et comme 3 B a pour manager 3 B je m'arrête la,
    car quand le client = le manager alors c'est qu'on est au sommet de la chaine.

    j'ai testé cette requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select * from CLIENT where zone = 8
    start with ( ID= 5 and IDCODE= B and zone = 8)
    connect by nocycle IDMGR = prior ID and MCODE = prior IDCODE
    le souci est qu'elle ne me ramène
    que
    5 B 4 B
    et s'arrête , elle ne remonte pas la hiérarchie jusqu'au sommet.
    au lieu de

    5 B 4 B
    4 B 3 B
    3 B 3 B
    Pourriez vous m’éclairer ?
    j'ai sans douter oublié un truc dans la requête mais je ne vois pas

    Merci

  2. #2
    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
    Il faut déjà intervertir le PRIOR :
    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
    21
    With Client as
    (
    select 1 as ID, 'B' as IDCODE, 1 as IDMGR, 'B' as MCODE, 8 as zone from dual union all
    select 2      , 'B'          , 3         , 'B'         , 8         from dual union all
    select 3      , 'B'          , 3         , 'B'         , 8         from dual union all
    select 4      , 'B'          , 3         , 'B'         , 8         from dual union all
    select 5      , 'B'          , 4         , 'B'         , 8         from dual
    )
        select ID, IDCODE, IDMGR, MCODE, ZONE, prior ID, prior IDMGR
          from CLIENT
    start with ID = 5
           and IDCODE = 'B'
           and zone = 8
    connect by nocycle
               prior IDMGR = ID
           and prior MCODE = IDCODE;
     
            ID I      IDMGR M       ZONE    PRIORID PRIORIDMGR
    ---------- - ---------- - ---------- ---------- ----------
             5 B          4 B          8                      
             4 B          3 B          8          5          4
    Maintenant il manque la ligne 3.
    Je pense qu'elle est filtrée à cause du NOCYCLE, comme elle boucle sur elle-même, le moteur la supprime du résultat.
    Une petite astuce afin d'éviter la boucle est de gérer ce cas avec un nullif :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
        select ID, IDCODE, IDMGR, MCODE, ZONE, prior ID, prior IDMGR
          from CLIENT
    start with ID = 5
           and IDCODE = 'B'
           and zone = 8
    connect by prior nullif(IDMGR, ID) = ID
           and prior IDCODE = MCODE;
     
            ID I      IDMGR M       ZONE    PRIORID PRIORIDMGR
    ---------- - ---------- - ---------- ---------- ----------
             5 B          4 B          8                      
             4 B          3 B          8          5          4
             3 B          3 B          8          4          3
    À approfondir néanmoins.

  3. #3
    Membre confirmé
    Inscrit en
    Décembre 2010
    Messages
    211
    Détails du profil
    Informations forums :
    Inscription : Décembre 2010
    Messages : 211
    Par défaut
    Bonjour,

    Tu veux absolument une seule requête ou bien tu peux utiliser une boucle?

  4. #4
    Membre éclairé
    Inscrit en
    Janvier 2004
    Messages
    532
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 532
    Par défaut
    merci waldar
    je vais tester et donc cela proviendrait du nocycle

    sinon oui
    je peux utiliser une boucle
    mais comme j'ai vu que les requete hierarchique existait je voulais d abord voir si c etait possible avec

  5. #5
    Membre éclairé
    Inscrit en
    Janvier 2004
    Messages
    532
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 532
    Par défaut
    j'ai l'impression que le deuxieme cas ne marche pas
    celui avec le nullif
    quand je le lances j 'ai ceci
    ORA-01436: CONNECT BY loop in user data

  6. #6
    Membre éclairé
    Inscrit en
    Janvier 2004
    Messages
    532
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 532
    Par défaut
    je pense que c'est impossible de le faire sans passer par une boucle
    ça a pas l'air vraiment au point le connect by

  7. #7
    Membre Expert Avatar de Drizzt [Drone38]
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Mai 2004
    Messages
    1 001
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Directeur de projet

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 001
    Par défaut
    De mémoire, mais je ne suis pas un expert dans le domaine, une requete recursive ne pourrait-elle pas convenir ?

    Tutoriel

Discussions similaires

  1. Réponses: 6
    Dernier message: 27/06/2007, 11h11
  2. Est-il possible de faire une requête hiérarchique ?
    Par Christophe Charron dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 21/03/2007, 14h32
  3. Réponses: 1
    Dernier message: 14/02/2007, 15h51
  4. requête hiérarchique et mysql4
    Par kitty2006 dans le forum Requêtes
    Réponses: 2
    Dernier message: 26/08/2006, 08h36
  5. Requête "hiérarchique"
    Par alxfg dans le forum Langage SQL
    Réponses: 7
    Dernier message: 09/02/2006, 02h27

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