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 :

Recherche sur sous-formulaire


Sujet :

VBA Access

  1. #1
    Débutant
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    482
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2004
    Messages : 482
    Points : 142
    Points
    142
    Par défaut Recherche sur sous-formulaire
    Bonjour,

    J'ai créé une zone de liste déroulante (Zone_recherche) dont le contenu est :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT tbl_etiquettes.Reference_client
    FROM tbl_etiquettes
    ORDER BY tbl_etiquettes.Reference_client;
    J'ai ensuite créé un bouton de commande :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Private Sub btn_recherche_Click()
     Dim rs As Object
     Set rs = Me.Recordset.Clone
     rs.FindFirst "[Reference_client] = " & Str(Nz(Me![Zone_recherche], 0))
     If Not rs.EOF Then Me.Bookmark = rs.Bookmark
     rs.Close
    End Sub
    Ce code fonctionne si les données se trouvent dans mon formulaire mais mes données se trouvent dans mon sous-formulaire.

    Que faut-il ajouter à ce code pour qu'il pointe sur le contrôle (Recherche_client) de mon sous-formulaire ?

    Merci pour votre aide.

  2. #2
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 331
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 331
    Points : 23 786
    Points
    23 786
    Par défaut
    Bonjour.

    Essaye :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Private Sub btn_recherche_Click()
     Dim rs As Object
     Set rs = Me.[Recherche_client].[Form].Recordset.Clone
     rs.FindFirst "[Reference_client] = " & Str(Nz(Me![Zone_recherche], 0))
     If Not rs.EOF Then Me.[Recherche_client].[Form].Bookmark = rs.Bookmark
     rs.Close
    End Sub
    et personnellement je préfère

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub btn_recherche_Click()
     Dim rs As Object
     Set rs = Me.[Recherche_client].[Form].Recordset
     rs.FindFirst "[Reference_client] = " & Str(Nz(Me![Zone_recherche], 0))
     rs.Close
    End Sub
    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

  3. #3
    Débutant
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    482
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2004
    Messages : 482
    Points : 142
    Points
    142
    Par défaut
    J'ai essayé ton code mais je reçois ce message d'erreur :

    Erreur d'exécution '2465':
    RS ne trouve pas le champ "I1" auquel il est fait reference dans votre expression.

    Je ne suis pas sûr que ton code pointe vers le sous-formulaire.

  4. #4
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 331
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 331
    Points : 23 786
    Points
    23 786
    Par défaut
    Bonjour.

    Essaye :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    rs.FindFirst "[Reference_client] = """ & Str(Nz(Me![Zone_recherche], 0)) & """"
    quand le champ chercher est
    • de type texte, il faut utiliser comme délimiteur le guillemet (") ou l'apostrophe. Personnellement je préfère le guillemet car il y en a rarement dans les textes en français.
    • de type date, il faut utiliser comme délimiteur le dièse (#) et il est conseillé de fomater la date au format mm/jj/aaaa ou aaaaa/mm/jj (mon préféré)
    • d'autre type, il ne faut pas de délimiteur


    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

  5. #5
    Débutant
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    482
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2004
    Messages : 482
    Points : 142
    Points
    142
    Par défaut
    Merci Marot_r mais toujours le meme message sur cette ligne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    rs.FindFirst "[Reference_client] = """ & Str(Nz(Me![Zone_recherche], 0)) & """"

  6. #6
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 331
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 331
    Points : 23 786
    Points
    23 786
    Par défaut
    Désolé je ne vois pas.

    Mets un point d'arrêt (clique dans la marge à gauche, cela va afficher un rond marron) sur la ligne rs.FindFirst "[Reference_client] = """ & Str(Nz(Me![Zone_recherche], 0)) & """".

    Une fois l'exécution arrêté, passe dans la fenêtre d'exécution immédiate en appuyant sur les touches [ctrl][g].
    Ensuite tape ? Me![Zone_recherche] [Enter] et vois ce que cela affiche. Est-ce bien la valeur rechercheé ?
    Après tape ? rs.fields.count [Enter] et vois ce que cela affiche. Est-ce bien le nombre de champs attendu ?
    Et puis tape ? rs.fields![Reference_client] [Enter] et vois ce que cela affiche. Est-ce bien un référence client ?

    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

  7. #7
    Débutant
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    482
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2004
    Messages : 482
    Points : 142
    Points
    142
    Par défaut
    J'ai à chaque fois des messages d'erreur
    Est-tu certain que ton code permet de pointer sur l'enregistrement de mon sous-formulaire ?
    Car le formulaire ne reprend aucune source.

  8. #8
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 331
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 331
    Points : 23 786
    Points
    23 786
    Par défaut
    Dans le code c'est le .[Form] qui permet de pointer sur le sous formulaire.

    Pour vérifier tu peux faire (toujours avec un point d'arrêt)

    ? Me.[Recherche_client].[Form].Name [enter]

    Cela devrait t'afficher le nom de ton sous-formulaire.

    J'ai à chaque fois des messages d'erreur
    Quel message, sur quelle instruction ?

    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

Discussions similaires

  1. mis à jour de champs sur sous formulaire
    Par nicolovitch dans le forum Access
    Réponses: 8
    Dernier message: 09/08/2006, 13h19
  2. Réponses: 2
    Dernier message: 11/07/2006, 13h01
  3. Recherche dans sous formulaires
    Par dfournier dans le forum IHM
    Réponses: 5
    Dernier message: 08/12/2005, 17h43
  4. probleme de vue sur sous formulaire
    Par fabrice518 dans le forum Access
    Réponses: 12
    Dernier message: 05/09/2005, 10h35
  5. Action sur sous-formulaire filtré
    Par thevenix dans le forum IHM
    Réponses: 4
    Dernier message: 20/06/2005, 00h39

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