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 :

CONNECT BY PRIOR


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Responsable technique
    Inscrit en
    Juillet 2005
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Responsable technique

    Informations forums :
    Inscription : Juillet 2005
    Messages : 23
    Par défaut CONNECT BY PRIOR
    Bonjour,

    J'ai une table de relations ("RELATION_EF") qui contient en gros un "id_pere", un "id_fils", un "nom de relation". Cette table "Relation_EF" est liée à une table "EF"
    Sur cette table de relations, il faut que je fasse un connect by prior pour récupérer les éléments des arborescences de relations. Voici un exemple visuel de ce qui existe en base :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    A                       D
      B                       E
        C                       F
          ...                      ...
    Voici le stéréotype de ma requete :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT id_fils
               FROM relation_ef
              WHERE (...)
         CONNECT BY PRIOR id_fils = id_pere
         START WITH id_pere IN (
                                SELECT id_ef
                                  FROM ef
                                 WHERE nom_ef IN
                                               ('A','D'))
    Le résultat va donc me produire une colonne "id_fils" contenant A, B ... F.
    Je souhaiterais ajouter une colonne à ce résultat qui contient 'A' ou 'D'. En gros, les valeurs à partir desquelles je démarre mon arbo et celles qui sont donc dans ma clause IN.

    Quelqu'un a t il une idée ?
    Merci d'avance.

  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
    Avec CONNECT_BY_ROOT à partir de 10g, ou SYS_CONNECT_BY_PATH avant.

  3. #3
    Membre averti
    Profil pro
    Responsable technique
    Inscrit en
    Juillet 2005
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Responsable technique

    Informations forums :
    Inscription : Juillet 2005
    Messages : 23
    Par défaut
    Effectivement, je viens de trouver :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT distinct id_fils, CONNECT_BY_ROOT id_pere
    ...
    Merci.

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

Discussions similaires

  1. CONNECT BY PRIOR oracle pour MySQL : possible ?
    Par thanaos dans le forum Requêtes
    Réponses: 1
    Dernier message: 12/12/2006, 15h11
  2. Connect By Prior ?
    Par eric95 dans le forum Hibernate
    Réponses: 2
    Dernier message: 05/12/2006, 09h52
  3. Réponses: 6
    Dernier message: 10/05/2006, 15h34
  4. [SQLSERVER] Connect by prior sous SQL Server
    Par marsup54 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 02/03/2006, 09h49
  5. quel équivalent de start with...connect by prior en DB?
    Par Mittou dans le forum Langage SQL
    Réponses: 5
    Dernier message: 18/10/2005, 14h02

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