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

Oracle Discussion :

Requete avec une condition sur le resultat [10g]


Sujet :

Oracle

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 44
    Points : 42
    Points
    42
    Par défaut Requete avec une condition sur le resultat [10g]
    Bonjour,
    J'ai besoin de votre aide pour formuler une requête.
    Je m'explique : J'ai une table NOEUDS qui contient la structure d'un arbre dont voici les champs :
    ID_NOEUD, ID_PERE, ID_DOCUMENT_ASSOCIE, TYPE_DOCUMENT, RANG
    ID_PERE nous donne l'id du pere qui est lui meme un id de la table NOEUDS.
    On a donc une table pour stocker un arbre.
    ID_DOCUMENT_ASSOCIE nous donne l'id du document associé à ce noeud, TYPE_DOCUMENT nous donne le type de document (soit 1 ou 2). RANG n'est pas important dans notre question.

    Mon but est de recupérer les enfants d'un noeud avec les informations ID_NOEUD ainsi que le titre du document associé à ce noeud. Le probleme, c'est que la table qui contient le titre du document dépend justement du type de document...Dans la premiere table de document (type 1), le champs titre est "INTITULE" et dans la deuxieme (type 2), c'est "TITRE".

    J'ai essayé cette requete :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    select distinct noeud.id_noeud, noeud.id_document_associe, noeud.type_document, noeud.rang, doc1.intitule, doc2.titre
    from noeuds noeud, documents_1 doc1, documents_2 doc2
    where noeud.id_pere = 13965
    and (doc1.id_document = noeud.id_document_associe or doc2.id_document = noeud.id_document_associe)
    order by rang;
    Elle fonctionne mais ne donne pas le bon resultat.

    En fait ce que je veux, c'est afficher soit doc1.intitule ou doc2.titre suivant la valeur de noeud.type_document

    Merci de notre aide !

  2. #2
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    c'est pas CONNECT BY qui serait adapté ?

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 44
    Points : 42
    Points
    42
    Par défaut
    Citation Envoyé par Fred_D
    c'est pas CONNECT BY qui serait adapté ?
    CONNECT BY ? Qu'est ce ? Je recherche sur google tout de suite !!!

  4. #4
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    une recherche sur le forum sera pas mal non plus

    exemple : http://www.developpez.net/forums/sho...=CONNECT+PRIOR

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 44
    Points : 42
    Points
    42
    Par défaut
    Ca y est,j 'ai pu recupere en une seule requete tout mon arbre !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT id_noeud, id_pere, id_document_associe, type_document, rang
    FROM noeuds_ir
    START WITH id_noeud = 16081
    CONNECT BY id_pere = PRIOR id_noeud
    ORDER SIBLINGS BY rang
    Il me reste à récupérer le titre du document. Je le pioche dans 2 tables différentes suivant la valeur de type_document (valeur 1 = DOCUMENTS_1 ; valeur 2 = DOCUMENTS_2).

    Une idée ???

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 44
    Points : 42
    Points
    42
    Par défaut
    J'ai trouvé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SELECT id_noeud,id_pere, type_document, rang, intitule, titre
    FROM noeuds_ir noeud
    LEFT OUTER JOIN DOCUMENTS_1 doc1
    ON noeud.id_document_associe = doc1.id_document
    LEFT OUTER JOIN DOCUMENTS_2 doc2
    ON noeud.id_document_associe = doc2.id_document
    START WITH noeud.id_noeud = 11876
    CONNECT BY noeud.id_pere = PRIOR noeud.id_noeud
    ORDER SIBLINGS BY noeud.rang
    Ca m'affiche l'arbre avec un des champs (soit intitulé ou titre) de rempli et l'autre à null.

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 13/11/2012, 18h54
  2. [VxiR2] Calcul de l'âge avec une condition sur indicateur
    Par KrusK dans le forum Deski
    Réponses: 2
    Dernier message: 18/12/2009, 15h37
  3. requete avec une condition
    Par how_much dans le forum Langage SQL
    Réponses: 2
    Dernier message: 02/06/2009, 16h23
  4. [MySQL] Mise à jour avec une condition sur une vue
    Par thor76160 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 02/03/2009, 01h00
  5. [XSLT]Trouver un noeud avec une condition sur ses sous-noeuds
    Par enguerran dans le forum XSL/XSLT/XPATH
    Réponses: 1
    Dernier message: 23/02/2007, 11h00

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