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

Langage SQL Discussion :

Comment traduire en SQL cette condition?


Sujet :

Langage SQL

  1. #1
    Inactif
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    92
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2005
    Messages : 92
    Points : 55
    Points
    55
    Par défaut Comment traduire en SQL cette condition?
    Bonjour,
    j'ai une table Etape avec 3 colonnes : Id_etape, Etape_Suiv, nom

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    id Etape   
    =======     
       1                     
       2                          
     
    Etap_Suiv
    ======
      2
      3
     
    Nom
    ====
    Lettre de demande AA
    Lettre de Relance
    Le but etant d'afficher :
    Le nom, et le nom de l'etape suivante soit par exemple pour la première ligne :
    Lettre de demande AA, Lettre de Relance


    Donc, en fait, le numero de l'Etape_Suiv, correspond à ID_Etape qui est donc le nom de l'etape Suivante de L'etape de id_etape 1

    est-ce que vous me suivez?
    en fait je retrouve le nom de l'etape suivante par rapport à Etap_Suiv qui est referencé via id_etape.

    Je dois afficher une liste des etapes associées avec leur etape_suivante mais je ne sais pas le traduire en SQL.
    Auriez-vous une idée? si je dois faire une sous requete?

  2. #2
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2005
    Messages
    1 673
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 1 673
    Points : 1 775
    Points
    1 775
    Par défaut
    Si tu as bien
    une table Etape avec 3 colonnes : Id_etape, Etape_Suiv, nom
    alors tes enregistrements se présentent de la manière suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    id_Etape  Etap_Suiv  Nom 
    ================================
       1          2      Lettre de demande AA
       2          3      Lettre de Relance
    Et la requête que tu demandes serait alors :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT T1.nom, T2.nom
    FROM MyTable T1
    INNER JOIN MyTable T2 ON (T1.Etape_Suiv = T2.Id_etape)

  3. #3
    Inactif
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    92
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2005
    Messages : 92
    Points : 55
    Points
    55
    Par défaut
    apparemment quand j'execute ton script SQL, j'ai un message d'erreur, la commande SQL ne se termine pas correctement..
    il ne prend pas INNER JOIN, on dirait.

  4. #4
    Inactif
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    92
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2005
    Messages : 92
    Points : 55
    Points
    55
    Par défaut
    INNER JOINT peut être utiliser une table elle même?

  5. #5
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2005
    Messages
    1 673
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 1 673
    Points : 1 775
    Points
    1 775
    Par défaut
    INNER JOINT peut être utiliser une table elle même?
    Oui, pourquoi voudrais-tu que ce soit interdit ?
    il ne prend pas INNER JOIN, on dirait
    la syntaxe de la clause JOIN doit dépendre de ton SGBD.
    Enlève le mot clé INNER et si ça ne marche toujours pas, Indiques moi ton SGBD (comme il l'est expliqué dans les règles du forum).

  6. #6
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2005
    Messages
    1 673
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 1 673
    Points : 1 775
    Points
    1 775
    Par défaut
    J'anticipe ta réponse et je te propose une solution qui devrait convenir quel que soit ton SGBD a priori :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT T1.nom, T2.nom 
    FROM MyTable T1, MyTable T2 
    WHERE T1.Etape_Suiv = T2.Id_etape
    Même si ça marche, indiques moi ton SGBD que l'on détermine la syntaxe exacte de la clause JOIN.

    Tu trouveras plus d'infos sur la syntaxe et le fonctionnement des jointures ici

  7. #7
    Inactif   Avatar de Médiat
    Inscrit en
    Décembre 2003
    Messages
    1 946
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 946
    Points : 2 227
    Points
    2 227
    Par défaut
    Est-ce qu'une jointure externe ne serait pas plus appropriée ? Je suppose que certaines étapes sont "terminales" et n'ont pas de suivantes...

    Si le INNER JOIN ne fonctionne pas, je suppose que le OUTER encore moins, donc il faut définitivement avoir le SGBDR....

  8. #8
    Inactif
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    92
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2005
    Messages : 92
    Points : 55
    Points
    55
    Par défaut
    merci pout toutes ces infos, je vais essayer de le resoudre...

  9. #9
    Futur Membre du Club
    Inscrit en
    Octobre 2004
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 9
    Points : 7
    Points
    7
    Par défaut
    je pense que ton probleme n'est pas dans la requette sql mais dans ta conception
    je te propose une solution :
    d'abort il te faut deux tables : Etape ( id_etape , nom_etape);
    EtapeSuiv (id_etape , id_etapesuiv);

    Etape
    id_etape nom_etape
    1_______ Lettre de demande AA
    2_______ Lettre de Relance
    3_______ Autre etape

    EtapeSuiv
    id_etape id_etapesuiv
    1______ 2
    2______ 3


    cette conception te permet de faire ce que tu veux en untilisant la reqette suivante :


    SELECT E1.nom_etape as Nom Etape , E2.nom_etape as Etape suivante
    FROM EtapeSuiv ES1, Etape E1, EtapeSuiv ES2 , Etape E2
    WHERE ES1.id_etape = E1.id_etape AND ES2.id_etapeSuiv = E2.id_etape

    le resultat de cette requette est

    Nom Etape_____________ Etape suivante
    Lettre de demande AA____ Lettre de Relance
    Lettre de Relance________ Autre etape

Discussions similaires

  1. Comment trouver les données selon cette condition?
    Par abouilyas dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 04/09/2011, 13h02
  2. Comment traduire une contrainte d'exclusion en sql Server ?
    Par lerieure dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 20/09/2010, 17h26
  3. Comment traduire une classe d'association en SQL ?
    Par NeedToHelp dans le forum Diagrammes de Classes
    Réponses: 1
    Dernier message: 14/10/2009, 10h04
  4. Réponses: 4
    Dernier message: 08/08/2006, 15h04
  5. [merise]traduire en sql une association réflexive
    Par omega dans le forum Langage SQL
    Réponses: 2
    Dernier message: 11/03/2004, 18h10

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