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

Requêtes MySQL Discussion :

Si A.champ = 1, faire jointure avec table B, sinon faire jointure avec table C


Sujet :

Requêtes MySQL

  1. #1
    Membre averti

    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    354
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Octobre 2011
    Messages : 354
    Points : 410
    Points
    410
    Par défaut Si A.champ = 1, faire jointure avec table B, sinon faire jointure avec table C
    Bonjour, je ne sais pas si il est possible de faire une requête de ce type :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT * from tableA as TA if(
                                                   champ=1, 
                                                   INNER JOIN tableB as TB on TC.id=TA.id_TX, 
                                                   INNER JOIN tableC as TC on TC.id=TA.id_TX
                                               ) ;
    En gros, si champ=1 je joins ma table A à ma table B, sinon, je joins ma table A à ma table C.

    J'ai essayé avec les CASE WHEN, mais je ne pense pas que ce soit possible. Je suis preneur sur toute autre alternative, à partir du moment où on reste sur une requête unique.

    Merci !

  2. #2
    Membre habitué
    Homme Profil pro
    Inscrit en
    Février 2013
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 79
    Points : 170
    Points
    170
    Par défaut
    Hmmm... Pas sûr de comprendre. "champ" c'est bien une colonne de la table A? Ca veut dire que selon les lignes, tu veux joindre la table B ou la table C?
    Quelque chose comme ca:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT * FROM tableA ta INNER JOIN tableB tb ON ( ta.id = tb.id AND ta.champ=1 )
    UNION
    SELECT * FROM tableA ta INNER JOIN tableC tc ON ( ta.id = tc.id AND ta.champ<>1 )

  3. #3
    Membre averti

    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    354
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Octobre 2011
    Messages : 354
    Points : 410
    Points
    410
    Par défaut
    Oui, champ est un champ de la table A. Merci je teste ça dès demain, je n'avais pas pensé à union, ça devrait fonctionner sans souci. Merci

  4. #4
    Membre averti

    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    354
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Octobre 2011
    Messages : 354
    Points : 410
    Points
    410
    Par défaut
    Cela fonctionne, j'ai dû rajouter un élément factice pour faire correspondre mon nombre d'éléments.

    Petite question, une requête avec Union équivaut-elle à deux requêtes en termes de ressources, ou tout est fait en un seul passage?

  5. #5
    Membre émérite Avatar de Drizzt [Drone38]
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Mai 2004
    Messages
    1 001
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Directeur de projet

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 001
    Points : 2 453
    Points
    2 453
    Par défaut
    Si tu laisses un UNION simple comme cela, la complexité sera supérieure à la somme des deux requêtes séparées car le UNION retire les doublons.

    Dans ton cas un UNION ALL probablement plus adapté (vu ce que tu imaginais dans ton post initial). Dans ce cas le résultat des deux requêtes est simplement concaténé sans suppression des doublons.
    Je ne réponds pas aux questions techniques par MP, le forum est là pour cela.

    La crypto c'est comme les flambys, une fois que tu as trouvé la languette tu as juste à tirer pour tout faire tomber.

    (\ _ /)
    (='.'=)
    Voici Lapinou. Aidez le à conquérir le monde
    (")-(") en le reproduisant

Discussions similaires

  1. Réponses: 6
    Dernier message: 21/05/2014, 23h49
  2. Réponses: 4
    Dernier message: 21/10/2010, 22h34
  3. Réponses: 2
    Dernier message: 22/03/2007, 16h19
  4. Réponses: 2
    Dernier message: 19/02/2007, 13h02
  5. jointure avec 2 id différent pour 1 seul table.
    Par vermo dans le forum Décisions SGBD
    Réponses: 2
    Dernier message: 10/11/2005, 15h19

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