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 :

[SQL] Sélectionner la plus petite valeur


Sujet :

Requêtes et SQL.

  1. #1
    Membre expérimenté Avatar de Gabout
    Homme Profil pro
    Utilisateur autodidacte
    Inscrit en
    Mai 2006
    Messages
    1 404
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Utilisateur autodidacte

    Informations forums :
    Inscription : Mai 2006
    Messages : 1 404
    Points : 1 683
    Points
    1 683
    Par défaut [SQL] Sélectionner la plus petite valeur
    Bonjour,

    Je souhaiterai afficher (par du code) la plus petite valeur de la sélection définie par le code SQL suivant.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT DateSerial(Year([Formation]),Month([Formation])+[Duree]-6,Day([Formation])) AS X
    FROM tbl_CATEGORIES INNER JOIN tbl_DEMANDES ON tbl_CATEGORIES.CCategorie_ID = tbl_DEMANDES.CCategorie
    WHERE (((DateSerial(Year([Formation]),Month([Formation])+[Duree]-6,Day([Formation])))>=Date()) AND ((tbl_DEMANDES.Suspension) Is Null) AND ((tbl_DEMANDES.Relance) Is Null) AND ((tbl_DEMANDES.Formation) Is Not Null));
    Avez-vous une solution à me proposer ?
    Gabout

  2. #2
    Membre chevronné
    Inscrit en
    Août 2006
    Messages
    1 588
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 1 588
    Points : 2 178
    Points
    2 178
    Par défaut
    Min pour les plus petites valeurs et TOP 1 pour pour la premiere
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT TOP 1 Min(DateSerial(Year([Formation]),Month([Formation])+[Duree]-6,Day([Formation]))) AS X
    FROM tbl_CATEGORIES INNER JOIN tbl_DEMANDES ON tbl_CATEGORIES.CCategorie_ID = tbl_DEMANDES.CCategorie
    WHERE (((DateSerial(Year([Formation]),Month([Formation])+[Duree]-6,Day([Formation])))>=Date()) AND ((tbl_DEMANDES.Suspension) Is Null) AND ((tbl_DEMANDES.Relance) Is Null) AND ((tbl_DEMANDES.Formation) Is Not Null));

  3. #3
    Membre expérimenté Avatar de Gabout
    Homme Profil pro
    Utilisateur autodidacte
    Inscrit en
    Mai 2006
    Messages
    1 404
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Utilisateur autodidacte

    Informations forums :
    Inscription : Mai 2006
    Messages : 1 404
    Points : 1 683
    Points
    1 683
    Par défaut
    Merci bien de ta réponse helas Ta solution est idéale !

    J'étais de mon côté parvenu à :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    Private Sub cmdProchaineRelance_Click()
        Dim oRst As DAO.Recordset
        Dim oDb As DAO.Database
        Dim sSQL As String
        sSQL = "SELECT DateSerial(Year([Formation]),Month([Formation])+[Duree]-6,Day([Formation])) AS LaDate " & _
               "FROM tbl_CATEGORIES INNER JOIN tbl_DEMANDES ON tbl_CATEGORIES.CCategorie_ID = tbl_DEMANDES.CCategorie " & _
               "WHERE (((DateSerial(Year([Formation]), Month([Formation]) + [Duree] - 6, Day([Formation]))) >= Date()) And ((tbl_DEMANDES.Suspension) Is Null) And ((tbl_DEMANDES.Relance) Is Null) And ((tbl_DEMANDES.Formation) Is Not Null)) " & _
               "ORDER BY DateSerial(Year([Formation]),Month([Formation])+[Duree]-6,Day([Formation]));"
     
        Set oDb = CurrentDb
        Set oRst = oDb.OpenRecordset(sSQL, dbOpenDynaset)
        MsgBox "La prochaine échéance est : " & oRst.Fields(0).Value
        oRst.Close
        oDb.Close
        Set oRst = Nothing
        Set oDb = Nothing
    End Sub
    Bref, j'ordonnai ma sélection par ordre croissant de date avant d'afficher le message... mais je ne étais pas sûr d'afficher systématiquement le premier recordset. Ton avis ?
    Gabout

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

Discussions similaires

  1. Sélectionner la plus petite valeur par année
    Par Catalyst dans le forum Langage SQL
    Réponses: 3
    Dernier message: 18/01/2012, 01h40
  2. [XSL]Récupérer les 5 plus petites valeurs de 10 éléments
    Par muad'dib dans le forum XSL/XSLT/XPATH
    Réponses: 1
    Dernier message: 02/03/2009, 18h04
  3. Afficher n plus petites valeurs
    Par nomade333 dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 12/02/2009, 17h07
  4. [MySQL] Retourner les plus petites valeurs d'une table
    Par Albafika dans le forum PHP & Base de données
    Réponses: 11
    Dernier message: 27/10/2008, 18h38
  5. Initialiser un double à la plus petite valeur possible.
    Par Pierre8r dans le forum Général Java
    Réponses: 4
    Dernier message: 05/03/2008, 20h36

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