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 et SQL. Discussion :

ce subquery ne peut avoir maximum qu'un seul résultat


Sujet :

Requêtes et SQL.

  1. #1
    Membre du Club
    Homme Profil pro
    Analyse système
    Inscrit en
    Février 2021
    Messages
    77
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Belgique

    Informations professionnelles :
    Activité : Analyse système
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2021
    Messages : 77
    Points : 51
    Points
    51
    Par défaut ce subquery ne peut avoir maximum qu'un seul résultat
    Bonjour

    mon but est de rentrer un numéro de client pour alors avoir la liste des tous les clients dont la date de leurs courses est antérieure à la date de la course du client rentré.

    Tout marche (p.ex le numéro 4) sauf lorsque je rentre le numéro d'un client qui a > 1 courses (p.ex 23): "ce subquery ne peut avoir maximum qu'un seul résultat" (traduit).
    Je sais qu'on a ce message parce que il y a "=" dans le subquery.
    Ma question est: comment faire pour que ça marche aussi avec le numéro 23?
    Merci
    Le fichier:
    Fichiers attachés Fichiers attachés

  2. #2
    Membre éprouvé Avatar de HDU71000
    Homme Profil pro
    Développement Access - En recherche de poste télétravail (invalide)
    Inscrit en
    Août 2016
    Messages
    716
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : Développement Access - En recherche de poste télétravail (invalide)

    Informations forums :
    Inscription : Août 2016
    Messages : 716
    Points : 1 023
    Points
    1 023
    Par défaut
    Bonjour,

    si ton client (23 par exemple) a plus d'une course, il faut prendre les autres clients qui ont une course inférieure à la date maxi du client 23 non ? Dans ce cas il te suffit de rajouter max(datecourse) dans ta sous-requête.

    Ou dis nous ce que tu voudrais que cela retourne.

    A+

  3. #3
    Membre du Club
    Homme Profil pro
    Analyse système
    Inscrit en
    Février 2021
    Messages
    77
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Belgique

    Informations professionnelles :
    Activité : Analyse système
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2021
    Messages : 77
    Points : 51
    Points
    51
    Par défaut
    Merci pour ta réponse.
    Oui, la date avant la date maximale.

    J'ai essayé ceci: (ici je rentre le nom du client (par ex. Stuyven (nr 4) et Geerts (nr 11)). Avec 'Geerts', j'ai de nouveau la même erreur.
    L'erreur est produite à cause du signe "=" tout à la fin. Tant que cela produira > 1 résultat, l'erreur persistera.

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT clients.nom, courses.datecourse
    FROM clients INNER JOIN courses ON clients.nrclient = courses.nrclient
    WHERE (courses.datecourse)<(select max(courses.datecourse) from courses where courses.[nrclient]=
    (select nrclient from clients where clients.nom = nomcl));

  4. #4
    Membre éprouvé Avatar de HDU71000
    Homme Profil pro
    Développement Access - En recherche de poste télétravail (invalide)
    Inscrit en
    Août 2016
    Messages
    716
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : Développement Access - En recherche de poste télétravail (invalide)

    Informations forums :
    Inscription : Août 2016
    Messages : 716
    Points : 1 023
    Points
    1 023
    Par défaut
    Tu as 2 "Geerts" d'où l'erreur
    Si tu saisis le numéro (11), tu n'as plus l'erreur

    Le mieux est d'utiliser non pas une boite de dialogue pour saisir, mais un formulaire pour choisir, cela évite les erreurs potentielles de saisies et c'est + convivial.

    A+

  5. #5
    Membre du Club
    Homme Profil pro
    Analyse système
    Inscrit en
    Février 2021
    Messages
    77
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Belgique

    Informations professionnelles :
    Activité : Analyse système
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2021
    Messages : 77
    Points : 51
    Points
    51
    Par défaut
    Merci. Ca marche effectivement.
    A+

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

Discussions similaires

  1. Parmi 3 cellules, une seule peut avoir une valeur différente de 0.
    Par EricQ dans le forum Macros et VBA Excel
    Réponses: 24
    Dernier message: 07/07/2008, 15h46
  2. Combien d'administrateur de site on peut avoir
    Par mghari11 dans le forum Servlets/JSP
    Réponses: 1
    Dernier message: 26/06/2008, 11h56
  3. Est-ce une configuration en laquelle on peut avoir confiance ?
    Par Danny Blue dans le forum Windows Forms
    Réponses: 3
    Dernier message: 29/01/2008, 19h03
  4. Créer une fenêtre flottante qui ne peut avoir le focus
    Par BestofMac dans le forum Composants VCL
    Réponses: 4
    Dernier message: 17/07/2002, 10h46

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