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 :

Date mini et Sous requêtes


Sujet :

Requêtes et SQL.

  1. #1
    Membre habitué
    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    660
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 78
    Localisation : France, Val d'Oise (Île de France)

    Informations forums :
    Inscription : Août 2005
    Messages : 660
    Points : 165
    Points
    165
    Par défaut Date mini et Sous requêtes
    Bonjour,

    Je voudrais obtenir la date de naissance Min pour les Me et Mr du champ Civilité de ma table.

    Voici ma requête qui me donne uniquement la date de Me.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    StrSql = "SELECT P.Civilité, P.NomAdhérent, P.Prénom, P.MillLicence, P.DateNaissance " & _
             "FROM [tbl Adhérents] AS P " & _
             "WHERE (((P.DateNaissance)=(SELECT Min(DateNaissance) " & _
             "FROM [tbl Adhérents]AS S " & _
             "WHERE S.Civilité IN ('Me','Mr') " & _
             "AND S.MillLicence=2009)));
    Merci pour votre aide.

    Salutations

  2. #2
    Modérateur
    Avatar de Chtulus
    Homme Profil pro
    Ingénieur
    Inscrit en
    Avril 2008
    Messages
    3 094
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Santé

    Informations forums :
    Inscription : Avril 2008
    Messages : 3 094
    Points : 8 678
    Points
    8 678
    Par défaut
    Bonjour,

    Au plus simple tu peux utiliser les OR
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    StrSql = "SELECT P.Civilité, P.NomAdhérent, P.Prénom, P.MillLicence, P.DateNaissance " & _
             "FROM [tbl Adhérents] AS P " & _
             "WHERE ((P.DateNaissance)=(SELECT Min(DateNaissance) " & _
             "FROM [tbl Adhérents]AS S " & _
             "WHERE (S.Civilité = 'Me' OR S.Civilité = 'Mr') " & _
             "AND S.MillLicence=2009);

  3. #3
    Membre habitué
    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    660
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 78
    Localisation : France, Val d'Oise (Île de France)

    Informations forums :
    Inscription : Août 2005
    Messages : 660
    Points : 165
    Points
    165
    Par défaut
    Bonsoir Chtulus,

    Merci pour ta réponse, mais j'obtient
    que l'année mini de Me, et pas de Mr.

    Salutations

  4. #4
    Modérateur
    Avatar de Chtulus
    Homme Profil pro
    Ingénieur
    Inscrit en
    Avril 2008
    Messages
    3 094
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Santé

    Informations forums :
    Inscription : Avril 2008
    Messages : 3 094
    Points : 8 678
    Points
    8 678
    Par défaut
    Bonsoir,

    Pourvu que les Dieux du forum n'aient rien vu !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    StrSql = "SELECT P.Civilité
              , P.NomAdhérent
              , P.Prénom
              , P.MillLicence
              , MIN(DateNaissance) " & _
     
             "FROM [tbl Adhérents] AS P " & _
             "WHERE (P.Civilité = 'Me' OR P.Civilité = 'Mr') " & _
             "AND P.MillLicence=2009 " _
             "GROUP BY ... ";

  5. #5
    Expert confirmé
    Avatar de vodiem
    Homme Profil pro
    Vivre
    Inscrit en
    Avril 2006
    Messages
    2 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Vivre
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 895
    Points : 4 325
    Points
    4 325
    Par défaut
    salut jmde, Chtulus
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    SELECT
       Civilité,
       NomAdhérent,
       Prénom,
       MillLicence,
       DateNaissance
    FROM [tbl Adhérents]
    WHERE
       (DateNaissance=DMin('DateNaissance','tbl Adhérents',"Civilité='" & Civilité & "' AND MillLicence=2009"))
       AND
       (Civilité IN ('Me','Mr'))
       AND
       (MillLicence=2009)

    sinon pour répondre à:
    Citation Envoyé par jmde
    Je voudrais obtenir la date de naissance Min pour les Me et Mr du champ Civilité de ma table.
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT
       Civilité,
       Min(DateNaissance)
    FROM [tbl Adhérents]
    WHERE (Civilité IN ('Me','Mr')) AND (MillLicence=2009)
    GROUP BY Civilité
    c'est suffisant.


    ps: si les dieux n'ont rien vu ils ne sont pas les seuls: tu es sur de ton sql? ;p

Discussions similaires

  1. Réponses: 3
    Dernier message: 06/03/2014, 12h07
  2. Sous-requête sur une date
    Par ERWPER dans le forum Langage SQL
    Réponses: 6
    Dernier message: 09/10/2008, 13h51
  3. Requêtes et sous requêtes
    Par lau2nyce dans le forum Langage SQL
    Réponses: 3
    Dernier message: 23/03/2004, 16h14
  4. suppression avec sous requête conditionnelle
    Par melmel dans le forum Requêtes
    Réponses: 8
    Dernier message: 19/03/2004, 00h20
  5. Réponses: 3
    Dernier message: 18/05/2003, 01h16

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