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 :

Utiliser des jointures de table avec une fonction récursive


Sujet :

SQL Oracle

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 13
    Points : 11
    Points
    11
    Par défaut Utiliser des jointures de table avec une fonction récursive
    Bonjour à tous,

    Je suis en train d'utiliser la fonctionnalité d'oracle sur la récursivité.
    Ca marche très bien lorsque j'utilise ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select SYS_CONNECT_BY_PATH(ih.child_id, ' - '), level
    from INV_HIERARCHIES ih
    start with ih.parent_id = 5011528
    connect by prior ih.child_id = ih.parent_id
    En revanche lorsque je veux utiliser une jointure avec une autre table comment faire?
    Ceci ne marche pas :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select SYS_CONNECT_BY_PATH(ih.child_id, ' - '), level, ii.NAME
    from INV_INVESTMENTS ii,
         INV_HIERARCHIES ih
    start with ih.parent_id = 5011528
    connect by prior ih.child_id = ih.parent_id
    where ii.id = ih.child_id
    Quelqu'un peut-il m'aider sur la bonne syntaxe?

    Merci beaucoup.
    Eric.

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    En positionnant bien le WHERE :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select SYS_CONNECT_BY_PATH(ih.child_id, ' - '), level, ii.NAME
    from INV_INVESTMENTS ii,
    INV_HIERARCHIES ih
    where ii.id = ih.child_id
    start with ih.parent_id = 5011528
    connect by prior ih.child_id = ih.parent_id
    Ou mieux :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
        select sys_connect_by_path(ih.child_id, ' - '), level, ii.name
          from inv_investments ii
               inner join inv_hierarchies ih
                 on ih.child_id = ii.id
    START with ih.parent_id = 5011528
    CONNECT by PRIOR ih.child_id = ih.parent_id
    Notez bien aussi les remarques suivantes tirées de la documentation officielle :
    Oracle processes hierarchical queries as follows:
    * A join, if present, is evaluated first, whether the join is specified in the FROM clause or with WHERE clause predicates.
    * The CONNECT BY condition is evaluated.
    * Any remaining WHERE clause predicates are evaluated.

  3. #3
    Membre régulier
    Inscrit en
    Juillet 2006
    Messages
    76
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 76
    Points : 81
    Points
    81
    Par défaut
    Oracle processes hierarchical queries as follows:
    * A join, if present, is evaluated first, whether the join is specified in the FROM clause or with WHERE clause predicates.
    * The CONNECT BY condition is evaluated.
    * Any remaining WHERE clause predicates are evaluated.
    Ca devrait eviter la jointure a faire avant la recherche recursive.

    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
    22
    WITH INV_HIERARCHIES AS
    (
    SELECT 1 AS id,null AS child_id FROM dual union ALL
    SELECT 2 , 1 FROM dual union ALL
    SELECT 3 , 1 FROM dual union ALL
    SELECT 4 , 2 FROM dual
    ),
    INV_INVESTMENTS AS
    (
    SELECT 1 AS id,'Durand' AS name FROM dual union ALL
    SELECT 2 ,'Dufour' FROM dual union ALL
    SELECT 3 ,'Cheng' FROM dual union ALL
    SELECT 4 ,'Moise' FROM dual
    )
    select hier,lv,name
    from
    (
    SELECT SYS_CONNECT_BY_PATH(ih.child_id, ' - ') as hier, level as lv, ih.id
    FROM INV_HIERARCHIES ih
    start WITH ih.id = 1
    connect BY prior ih.id = ih.child_id
    ) req JOIN INV_INVESTMENTS ii ON ii.id = req.id

  4. #4
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Citation Envoyé par boutade80 Voir le message
    Ca devrait eviter la jointure a faire avant la recherche recursive.
    ...
    Oui mais, ça ne donne pas forcement le même résultat.

Discussions similaires

  1. Jeu du plus ou moins avec une fonction récursive
    Par Pimousse22 dans le forum C
    Réponses: 6
    Dernier message: 29/10/2014, 21h26
  2. Réponses: 7
    Dernier message: 15/07/2011, 15h22
  3. [XL-2003] utiliser des chiffres a virgules avec une inputbox
    Par bosk1000 dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 16/06/2011, 08h56
  4. Permutation avec une fonction récursive
    Par nypahe dans le forum Débuter avec Java
    Réponses: 1
    Dernier message: 29/04/2009, 07h32
  5. [Débutant] Utiliser des listes en argument d'une fonction
    Par erkenbrand dans le forum Windows Forms
    Réponses: 10
    Dernier message: 29/05/2008, 12h56

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