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 :

Deux jointures vers la même table


Sujet :

Langage SQL

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    248
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Février 2007
    Messages : 248
    Points : 231
    Points
    231
    Par défaut Deux jointures vers la même table
    Bonjour,

    Je suis en train de tester une nouvelle organisation des libellés utilisés dans les différents menu déroulant de mon site...

    J'ai donc une table entreprise avec par exemple les champs nb_employe et statut. J'ai une autre table avec tous les libelles.

    J'ai donc besoin de faire la requête suivante. Pour le coup ce que j'ai fait focntionne, mais j'ai deux questions :
    - est-ce possible d'avoir une requête plus simple que de mettre deux alias différents ?
    - que pensez-vous de cette organisation ? C'est pratique pour la mise en place car, beaucoup moins de table à créer, mais à entretenir je ne sais pas...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT * FROM test_ent AS E
    LEFT OUTER JOIN test_libelles AS L ON E.nb_employe=L.lib_id
    LEFT OUTER JOIN test_libelles AS L1 ON E.statut=L1.lib_id
    J'espère avoir été clair et merci par avance !!

  2. #2
    Membre expérimenté
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2010
    Messages : 793
    Points : 1 327
    Points
    1 327
    Par défaut
    Bonjour,

    je pense que c'est très bien comme ça, mais ça n'engage que moi
    ;-)

  3. #3
    Membre actif
    Inscrit en
    Janvier 2012
    Messages
    145
    Détails du profil
    Informations forums :
    Inscription : Janvier 2012
    Messages : 145
    Points : 226
    Points
    226
    Par défaut
    Quelques questions:
    • Les valeurs que l'on retrouve dans lib_id peuvent elles être égales à nb_employe (E.nb_employe=L.lib_id) et aussi à statut (E.statut=L1.lib_id)?
    • L et L1 peuvent elles être identiques?

  4. #4
    Membre chevronné
    Homme Profil pro
    Inscrit en
    Août 2009
    Messages
    510
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Août 2009
    Messages : 510
    Points : 2 157
    Points
    2 157
    Par défaut
    Au niveau de la requete, à mon avis, il n'y a pas moyen de faire plus simple.

    En fait d'un point de vue modélisation, ta table de libellés contient plusieurs relations :
    1 - La liste des libellés de nombre d'employés (moins de 50, entre 50 et 100...je suppose) je suppose.
    2 - La liste de statut de ??? (salariés cadre, non cadre, SA , SARL ????)

    Tu associe ta table à deux relations différentes cela fait donc deux jointures...

    Ton modèle de données m'a l'air un peu bizarre.

  5. #5
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    248
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Février 2007
    Messages : 248
    Points : 231
    Points
    231
    Par défaut
    Pour être plus clair, cette idée m'est venue en regardant un autre projet...

    Actuellement, je fonctionne avec le principe suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT * FROM test_ent AS E
    LEFT OUTER JOIN test_libelles AS L ON E.nb_employe=L.lib_id
    LEFT OUTER JOIN test_libelles AS L1 ON E.statut=L1.lib_id
    Une table "test_ent" qui liste des entreprises sous la forme :
    id : id de l'entreprise
    nom : nom de l'entreprise
    nb_employ : nombre d'employés
    statut : statut juridique de l'entreprise

    j'avais ensuite une table nb_employé avec les libellés (1 à 10, + de 50, ...) et une table statut juridique (asssociation, sarl,...).

    L'idée était donc de faire une table unique pour l'ensemble des tables qui ne servait qu'à stocker des libellés...

    j'aurais donc une table genre libelle avec un contenu du type :

    id - libelle - categorie
    1 - 1 à 10 - nb_employ
    2 - + de 50 - nb_employ
    5 - association - statut
    6 - sarl - statut

    A bien y réfléchir, je suis resté sur le fonctionnement de départ avec une table distincte pour chaque élément. Mais je réfléchissais à cette organisation. Et elle a quand même des avantages... je voulais donc demander l'avis de personne qui ont une meilleure expertise que moi !

  6. #6
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    Mise à part péter totalement les contraintes d'intégrité ca ne change pas grand chose.

    Dans votre modèle initiale vous êtes sûr d'avoir les bonnes données au bon endroit.

    Avec cette nouvelle modélisation rien ne vous empêchera d'avoir pour un statut juridique le libellé : 0 - 50 employé

  7. #7
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 048
    Points
    34 048
    Billets dans le blog
    14
    Par défaut
    albedo0, ce que vous avez essayé de faire est de la modélisation par métadonnées.
    Dans certains cas, cela peut s'avérer conceptuellement pratique, voir nécessaire, mais c'est assez peu pratique à utiliser.

    Dans l'exemple simple que vous présentez, cela me semble superflu.

    Règle de gestion :
    une entreprise a un statut juridique et un statut juridique peut s'appliquer à plusieurs entreprises.

    MCD :
    statut_juridique -0,n----appliquer----1,1- entreprise

    Tables :
    statut_juridique (stj_id, stj_libelle...)
    entreprise (ent_id, ent_id_statut_juridique, ent_raison_sociale...)

    Règle de gestion :
    Une entreprise a une taille et une taille peut catégoriser plusieurs entreprises.

    MCD :
    taille -0,n----catégoriser----1,1- entreprise

    Tables :
    taille (tai_id, tai_libelle, tai_nb_employes_mini, tai_nb_employes_maxi)
    entreprise (ent_id, ent_id_statut_juridique, ent_id_taille, ent_raison_sociale...)

  8. #8
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    248
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Février 2007
    Messages : 248
    Points : 231
    Points
    231
    Par défaut
    Bon ça confirme ce que je me disais... Merci beaucoup !

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 16/07/2013, 15h02
  2. [AC-2002] Deux formulaires qui pointent vers une même table
    Par antezi dans le forum IHM
    Réponses: 2
    Dernier message: 11/02/2010, 21h27
  3. Deux jointures vers la même table ?
    Par JYFJYF dans le forum Requêtes
    Réponses: 9
    Dernier message: 27/01/2010, 16h02
  4. [MySQL] Jointure: Avec deux champs d'une même table
    Par Vinuto dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 25/11/2008, 20h10
  5. Jointure entre deux champs d'une même table
    Par oubli dans le forum Requêtes
    Réponses: 8
    Dernier message: 11/12/2007, 16h20

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