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

VBA Access Discussion :

MsgBox avec RecordSet et requete


Sujet :

VBA Access

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre chevronné Avatar de binouzzz19
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    385
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2007
    Messages : 385
    Par défaut
    Bonjour a toutes et a tous !!

    Je viens de regarder dans le forum pour faire ceci :

    Je voudrais que pour chaque personne ayant un nouveau contrat dans quelques mois, un msgBox apparaisse avec le nom, le prénom de la personne pour effectuer un rappel !!

    J'effetue cette action au chargement de ma page principale, cela fonctionne mais seulement pour la premiere personne, jaimerais que ca me le fasse pour toutes les personnes concernées!!

    J'ai trouvé cette solution, qui donc ne fonctionne que pour la premiere personne

    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
    18
    19
    20
    Private Sub Form_Load()
     
        'DECLARATION
        Dim oRst As DAO.Recordset
        Dim oDb As DAO.Database
     
        'AFFECTATION
        Set oDb = CurrentDb
        Set oRst = oDb.OpenRecordset("SELECT Carriere.*, Personnel.nom, Personnel.prenoms FROM Personnel LEFT JOIN Carriere ON Personnel.numEns=Carriere.numEns WHERE Carriere.dateFin > Date()", dbOpenDynaset)
     
        'EXECUTION
        MsgBox oRst.Fields("nom").Value
     
        'Libération des objets
        oRst.close
        oDb.close
        Set oRst = Nothing
        Set oDb = Nothing
     
    End Sub
    Bien sur j'ai mis ici seulement Date() pour faire un test au préalable !!
    De plus j'avais essayé de mettre prenoms a la suite du nom mais cela ma mis une erreur !!

    Je me suis dit que je devais surement faire une boucle mais je ne connais pas la syntaxe !!

    Pouvez vous m'aider svp !!

    Cordialement

    je tiens a préciser que le bout de code a été trouvé dans le forum

  2. #2
    Membre Expert
    Avatar de pc75
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    3 662
    Détails du profil
    Informations personnelles :
    Âge : 70
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2004
    Messages : 3 662
    Par défaut
    Bonjour,

    Il faut que tu boucles sur ton recordset

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    do while not oRst.eof
       MSGBOX .....
       oRst.MoveNext
    loop

  3. #3
    Membre Expert
    Avatar de Mahefasoa
    Homme Profil pro
    Manager IT
    Inscrit en
    Octobre 2003
    Messages
    835
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations professionnelles :
    Activité : Manager IT

    Informations forums :
    Inscription : Octobre 2003
    Messages : 835
    Par défaut
    c.a.d.
    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
     
    Private Sub Form_Load()
     
        'DECLARATION
        Dim oRst As DAO.Recordset
        Dim oDb As DAO.Database
     
        'AFFECTATION
        Set oDb = CurrentDb
        Set oRst = oDb.OpenRecordset("SELECT Carriere.*, Personnel.nom, Personnel.prenoms FROM Personnel LEFT JOIN Carriere ON Personnel.numEns=Carriere.numEns WHERE Carriere.dateFin > Date()", dbOpenDynaset)
     
        If oRst.RecordCount<>0 Then
            oRst.MoveFirst
            Do While Not oRst.EOF
               'EXECUTION
                MsgBox oRst.Fields("nom").Value
                oRst.MoveNext
                DoEvents
            Loop
        End If
        'Libération des objets
        oRst.close
        oDb.close
        Set oRst = Nothing
        Set oDb = Nothing
     
    End Sub

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

Discussions similaires

  1. erreur 3201 sur une requete INSERT avec recordset
    Par forzaxelah dans le forum VBA Access
    Réponses: 1
    Dernier message: 22/01/2012, 08h01
  2. resultat requete avec recordset
    Par santacrus dans le forum VBA Access
    Réponses: 4
    Dernier message: 13/09/2008, 16h19
  3. Requete avec recordset ADODB vb6 et Access 2000 (jet 4.0)
    Par mathieuleclerc dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 22/09/2006, 10h54
  4. Réponses: 19
    Dernier message: 07/06/2006, 08h06
  5. Requete avec une sous-requete... Ne fonctionne qu'a moitie..
    Par mythtvtalk.com dans le forum MS SQL Server
    Réponses: 10
    Dernier message: 18/08/2003, 09h54

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