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 :

[MySQL] Sous-requête renvoyant plus d'un enregistrement


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    110
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 110
    Points : 62
    Points
    62
    Par défaut [MySQL] Sous-requête renvoyant plus d'un enregistrement
    Bonjour tout le monde!!

    Je suis étudiant en informatique et je dois développer un logiciel qui intérroge une base de donnée pour mon projet de bts seulement je me heurte à un problème.

    j'exécute cette requète:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from client where IdAdresse=(select IdAdresse from adresse WHERE CodePost=(select CodePost from localite where Ville='douai'))
    seulement la sous requète
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (select IdAdresse from adresse WHERE CodePost=(select CodePost from localite where Ville='douai'))
    renvoie plusieurs résultat (1 2 5 7) qui sont des valeurs de IdAdresse. Je voudrais donc savoir comment faire pour tester si IdAdresse fait parti d'un de ces chiffres.

    Je vous remercie d'avance et vous souhaite bonne continuation!!

  2. #2
    Membre averti Avatar de Rei Angelus
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2006
    Messages
    292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mars 2006
    Messages : 292
    Points : 356
    Points
    356
    Par défaut
    Tu remplaces == par IN
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    select * 
    from client
    where IdAdresse in (select IdAdresse
                from adresse
                WHERE CodePost = (select CodePost
                          from localite
                                          where Ville='douai'))

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    110
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 110
    Points : 62
    Points
    62
    Par défaut
    Merci beaucoup Rei Angelus tu as résolu mon problème!!!!
    Bonne continuation !!

  4. #4
    Membre averti Avatar de Rei Angelus
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2006
    Messages
    292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mars 2006
    Messages : 292
    Points : 356
    Points
    356
    Par défaut
    Juste une petite remarque sur mon SGBD les temps de traitements des IN peuvent être très long suivant le nombre d'enregistrements. Je passe généralement par EXISTS.

    Cela devrait donné un truc du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    select * 
    from client
    where exists (select 1
                from adresse
                WHERE adresse.IdAdresse = client.IdAdresse
                AND CodePost = (select CodePost
                                        from localite
                                        where Ville='douai'))
    A voir suivant tes besoins et ACCESS.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    110
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 110
    Points : 62
    Points
    62
    Par défaut
    moi il s'agit d'une base de donnée mysql sur serveur dédié et comme c'est pour le bts il n'y aura pas beaucoup d'enregistrements.

    Merci encore ton aide m'a bien fait avancer!!

  6. #6
    Membre averti Avatar de Rei Angelus
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2006
    Messages
    292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mars 2006
    Messages : 292
    Points : 356
    Points
    356
    Par défaut
    Oups !!! C'était sur un autre post que l'on parlait d'ACCESS

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

Discussions similaires

  1. MySql sous Windows plus lent que MySql sous Unix/Linux
    Par randriano dans le forum Administration
    Réponses: 4
    Dernier message: 28/03/2014, 15h07
  2. Comment désinstaller MySQL sous linux
    Par nahmsath dans le forum Installation
    Réponses: 5
    Dernier message: 18/09/2007, 10h46
  3. Chemin d'accès de MySQL sous linux
    Par sylvain_neus dans le forum Installation
    Réponses: 6
    Dernier message: 17/03/2004, 10h39
  4. installation 'automatique' de mysql sous win9x ?
    Par greystock dans le forum Installation
    Réponses: 3
    Dernier message: 07/03/2004, 03h06
  5. requête mysql sous php
    Par remi59 dans le forum Débuter
    Réponses: 9
    Dernier message: 03/07/2003, 10h39

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