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

Développement SQL Server Discussion :

Passer relation Enfant - Parent à Descendant - Ascendant


Sujet :

Développement SQL Server

  1. #1
    Membre actif
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2008
    Messages
    464
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Mars 2008
    Messages : 464
    Points : 268
    Points
    268
    Par défaut Passer relation Enfant - Parent à Descendant - Ascendant
    Bonjour,
    C'est un peu classique comme question mais je n'arrive pas à savoir comment je peux gérer ça avec une requête (sans passer par des procédures stockées).

    J'ai une table relation :
    avec deux champs Parent Enfant
    Avec
    Enfant ;Parent
    4; 3
    3; 2
    2; 1

    Et je voudrais passer à une requête qui me sort
    Ancetre ; Descendant
    1; 2
    1; 3
    1; 4
    2; 3
    2; 4
    3; 4

    J'ai essayé de taper dans les requêtés CTE mais je ne m'en sors pas avec toutes les combinatoires

    1; 2
    1; 3
    1; 4
    je sais faire mais

    2; 3
    2; 4
    je n'y arrive pas.

  2. #2
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    Indiquez la requete qui vous permet d'obtenir ça :

    Citation Envoyé par VITALTH
    1; 2
    1; 3
    1; 4
    je sais faire mais

    Car il ne doit pas manquer grand chose pour obtenir ce que vous voulez !

  3. #3
    Membre actif
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2008
    Messages
    464
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Mars 2008
    Messages : 464
    Points : 268
    Points
    268
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    with Reccurs (Ancetre, Descendant) 
    	as (SELECT Parent Ancetre,
                                   Enfant Descendant
                        FROM [Parent Enfant]
                        union all 
    	      SELECT r.Ancetre,
                                    pe.Enfant as Descendant
    	       FROM Reccurs r INNER JOIN [Parent Enfant] pe ON r.[Descendant] = pe.[Parent])
    SELECT * FROM Reccurs 
    OPTION (MAXRECURSION, 0)

  4. #4
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    je disais qu'il ne manquerait pas grand chose... je dirai même qu'il ne manque rien !

    Votre requete est correcte et devrait donner le résultat voulu...

  5. #5
    Membre actif
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2008
    Messages
    464
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Mars 2008
    Messages : 464
    Points : 268
    Points
    268
    Par défaut
    Non je ne crois pas parce que je pense qu'elle ne me donner pas les résultats ancetres - descendant quand l'ancètre n'est pas l'ancètre racine.

    Dans mon exemple : les valeurs
    2; 3
    2; 4
    3; 4

  6. #6
    Membre actif
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2008
    Messages
    464
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Mars 2008
    Messages : 464
    Points : 268
    Points
    268
    Par défaut
    Non mais c'est bon, je n'ai rien dit ça marche.
    C'est parce qu'à la base dans mon intitialisation j'ai pris tous les enregistrements qui n'avaient pas de parent

Discussions similaires

  1. Requête relation enfant parent : 1 table
    Par irid dans le forum Développement
    Réponses: 1
    Dernier message: 12/01/2011, 14h26
  2. Relation Parent/Enfant - Enfant/Parent
    Par zax-tfh dans le forum Services Web
    Réponses: 1
    Dernier message: 02/03/2010, 17h30
  3. [C#] Formulaires enfants - parents
    Par Gold.strike dans le forum Windows Forms
    Réponses: 4
    Dernier message: 24/07/2006, 14h24
  4. Heritage enfant -> parent
    Par crazy-spans dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 21/07/2006, 20h31
  5. [CSS] enfants ...parents... super exercice...
    Par luta dans le forum Mise en page CSS
    Réponses: 7
    Dernier message: 14/04/2006, 16h22

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