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 :

recherche valeur haute


Sujet :

Requêtes et SQL.

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2007
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 44
    Points : 34
    Points
    34
    Par défaut recherche valeur haute
    Bonjour,
    dans un formulaire, j'utilise le code suivant, repris sur ce forum.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub Form_BeforeInsert(Cancel As Integer)
      NuméroBonCommande = CStr((Year(Now) * 10000) + Nz(DCount("[NuméroBonCommande]", "Commandes", "[NuméroBonCommande] Like '" & Year(Now) & "*'"), 0) + 1)
    End Sub
    je voudrais lorsque je lance une requete, pouvoir recupérer la valeur du champ la plus elevé.

    Avez vous des piste, j'ai essayé max mais ... non

    Merci à tous

    Manu

  2. #2
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    Bonsoir,

    C'est pourtant bien max qu'il faut utiliser.

    En SQL :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT Max(MonChamp) FROM MaTable
    Ou alors, je n'ai pas compris la question

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2007
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 44
    Points : 34
    Points
    34
    Par défaut bizarre
    le forum, tofalu,

    J'ai déjà essayer mais cela ne marche toujours pas

    Mon champ et au format texte est ce génant

    Manu

  4. #4
    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 Tofalu et campello,

    j'ai le souvenir d'avoir pondu un truc comme ca...

    attention de reprendre dans le contexte (remise à zéro chaque année) et de comprendre la nuance avec un DMax():
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    NuméroBonCommande = CStr((Year(Now) * 10000) + Nz(DMax("[NuméroBonCommande]", "Commandes", "[NuméroBonCommande] Like '" & Year(Now) & "*'"), 0) + 1)
    ou autrement comme cela:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    NuméroBonCommande = CStr((Year(Now) * 10000) + Nz(DMax("[NuméroBonCommande]", "Commandes"), 0) + 1)
    qui à une nuance près ne donne pas forcement le même résultat...


  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2007
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 44
    Points : 34
    Points
    34
    Par défaut petite aide sup
    Bonjour,
    J'ai essayé... mais j'y parviens toujours pas.
    POuvez m'aider svp avec le fichier joint
    Merci bcp
    Manu
    Fichiers attachés Fichiers attachés

  6. #6
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 768
    Points
    7 768
    Par défaut
    Bonsoir,

    Ton champ [N°Commande] est de type texte au format "aaaa0000"
    où aaaa est l'année et 0000 un compteur.

    DMax renvoie soit une chaîne au même format, soit Null.
    Dans le premier cas il ne faudra pas ajouter l'année*10000, car on l'a déjà.
    Dans le deuxième, il faut que Nz remplace Null par l'année*10000

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Private Sub Form_BeforeInsert(Cancel As Integer)
      Dim lgNumSuivant As Long
      lgNumSuivant = CLng(Nz(DMax("[N°Commande]", "bd", "[N°Commande] Like '" & Year(Now) & "*'"), Year(Now) * 10000)) + 1
      N°Commande = CStr(lgNumSuivant)
    End Sub
    A+

  7. #7
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2007
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 44
    Points : 34
    Points
    34
    Par défaut fonction dmax
    Bonjour,

    J'ai utilisé le code fourni par LedZeppII.

    Ensuite je vais mettre dans une requête la fonction DMAX.
    Elle n'y ai pas . Je pense que je fais fausse route.

    En fait, je me sers pour le moment d'une requête qui me demande de tapez un n° de commande. Cette requête fait l'objet d'un état, qui me donne la commande en fonction du n° renseigné.

    Ce que je veux mettre en place, c'est que lorsque je lance l'état, je n'ai pas besoin de noter mon N° de commande, il va me chercher le dernier enregistré.

    Pouvez vous me donner votre avis svp

    Merci à tous

    Manu

  8. #8
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Février 2007
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 44
    Points : 34
    Points
    34
    Par défaut fonction agregat dans ... where
    Bonjour le forum,

    Je me casse la tête sur cette commande. (mon n° max saisie)
    Je me suis dit :
    Je vais créer un compteur n° auto en parrallèle de mon n° de commande.
    Forcement le n° max sera à chaque coup en concordance avec mon denier n° de commande.
    J'ai mis cette fomule dans ma requete : max([n°])

    J'ai le message suivant :
    impossible d'avoir une fonction d"agregat dans la clause where (bd.N°=min([n°]).

    Quelquu'un peux m'aider...

    Je n'ai pas la fonction DMAX comme annoncé plus haut......?

    Merci d'avance à tous

    Manu

  9. #9
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 768
    Points
    7 768
    Par défaut
    Bonsoir,

    Sur la base de ta pièce jointe, voici une requête qui sélection les enregistrements de la table bd, dont le champ N°Commande est égal à la valeur max de ce champ

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT bd.N°, bd.N°Commande, bd.NOM, bd.Prix
    FROM bd
    WHERE (((bd.N°Commande)=DMax("N°Commande","bd")));
    En mode création cela donne comme critère pour le champ N°Commande
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MaxDom("N°Commande";"bd")
    MaxDom est la traduction locale de DMax.

    A+

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

Discussions similaires

  1. Excel fonction si+recherche valeur
    Par zoukah dans le forum Excel
    Réponses: 11
    Dernier message: 16/06/2008, 08h58
  2. Recherche Valeur d'un enregistrement
    Par Daniel MOREAU dans le forum Access
    Réponses: 7
    Dernier message: 11/04/2006, 13h39
  3. Recherche valeur dans table Access
    Par Stefloulou dans le forum Access
    Réponses: 1
    Dernier message: 05/11/2005, 08h45
  4. [Tableaux] Recherche valeur dans tableaux
    Par Kaimann dans le forum Langage
    Réponses: 10
    Dernier message: 21/10/2005, 11h57
  5. recherche valeur maximale entre deux champs
    Par maysa dans le forum Langage SQL
    Réponses: 6
    Dernier message: 25/05/2005, 09h40

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