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 :

Ouverture d'un formulaire sur un enregistrement précis


Sujet :

VBA Access

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 22
    Points : 13
    Points
    13
    Par défaut Ouverture d'un formulaire sur un enregistrement précis
    Bonjour à tous !


    Voilà mon souci :


    Je dispose d'un premier formulaire (formulaire1) sur lequel se trouve une liste basée sur une table "Personnes". Cette liste (liste1) affiche le contenu des champs "nom" et "prénom" pour chaque enregistrement de la table "Personnes".


    Lorsque je double clique sur un élément de la liste, un deuxième formulaire s'ouvre (formulaire 2). Ce formulaire est également basé sur la table "Personnes". Il est prévu pour afficher des informations supplémentaires sur la personne double cliquée précédemment.


    Mon problème arrive ici :

    Je souhaite que le formulaire 2 me permette de naviguer entre tous les enregistrements de la table "Personnes". Mais je veux qu'il s'ouvre sur l'enregistrement correspondant à la personnes sélectionnée dans la liste 1.


    J'ai essayé avec quelque chose du genre, qui me permet de me déplacer automatiquement à l'enregistrement recherché lors de l'ouverture du formulaire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Private Sub Form_Open (Cancel As Integer)
        While ID_Personne <> Formulaires![Formulaire1]![Liste1]
            DoCmd.GoToRecord
        Wend
    End Sub

    Ca fonctionne, sauf que j'ai environ 37000 enregistrements dans la table "Personnes", donc si l'enregistrement sélectionné se trouve vers la fin c'est assez long.

    Y aurait-il une autre solution, qui me permettrait de conserver la possibilité de navigation entre les enregistrements ?

  2. #2
    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 759
    Points
    7 759
    Par défaut
    Bonsoir,

    tu peux faire ça dans le code qui ouvre le formulaire.
    Code vba : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Dim strForm As String
    strForm = "Formulaire2"
    ' Ouvre le formulaire
    DoCmd.OpenForm strForm
    ' Donne le focus au contrôle où faire la recherche
    Forms(strForm).ID_Personne.SetFocus
    ' Rechercher valeur dans le contrôle en cours
    DoCmd.FindRecord Me.Liste1, acEntire, , acDown
    End Sub

    Autre méthode par Bookmark:
    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
    Dim strForm As String, rs As DAO.Recordset
    strForm = "Formulaire2"
    DoCmd.OpenForm strForm
    Set rs = Forms(strForm).RecordsetClone
    rs.MoveFirst
     
    ' ID_Personne étant un champ de la source de données de Formulaire2
    ' Deux syntaxes possibles selon type du champ, Texte ou Nombre
    ' Ne conserver qu'une des deux
    ' * Si Texte
    rs.FindFirst "[ID_Personne]='" & Me.Liste1 & "'"
    ' * Si Nombre
    rs.FindFirst "[ID_Personne]=" & Me.Liste1
     
    If Not rs.EOF Then
       Forms(strForm).Bookmark = rs.Bookmark
    End If
    Set rs = Nothing
    A+

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 22
    Points : 13
    Points
    13
    Par défaut
    Ca marche merci

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

Discussions similaires

  1. [AC-2010] Ouverture de formulaire sur un enregistrement précis
    Par theolivier dans le forum IHM
    Réponses: 20
    Dernier message: 24/09/2012, 18h40
  2. [Toutes versions] Probleme ouverture formulaire sur un enregistrement préci
    Par azur123 dans le forum VBA Access
    Réponses: 1
    Dernier message: 17/08/2012, 23h43
  3. [AC-2003] Ouverture d'un formulaire sur un enregistrement précis
    Par Jeanpierre71 dans le forum IHM
    Réponses: 7
    Dernier message: 10/10/2011, 17h56
  4. Réponses: 1
    Dernier message: 06/07/2006, 14h44
  5. Ouverture d'un formulaire sur un enregistrement défini
    Par Nabouille dans le forum Access
    Réponses: 10
    Dernier message: 23/03/2006, 23h46

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