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

Access Discussion :

formulaire de recherche avec liste déroulante entre 3 tables ?


Sujet :

Access

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Août 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 88
    Points : 47
    Points
    47
    Par défaut formulaire de recherche avec liste déroulante entre 3 tables ?
    Bonjour,
    Voilà ma question :

    J’ai une BD avec 3 tables :
    SAVOIRFAIRE (ID_SAV, INTITULE)
    EMPLOYE (ID_EMP, NOM)
    Et une table de croisement entre les 2 précédentes car elles ont une relation « N,N »,
    donc EMPSF (IDSAV, ID_EMP).

    Je cherche à faire un formulaire de recherche avec :
    1 liste déroulante avec INTITULE
    et une zone de liste qui affichera les NOM (des EMPLOYE) qui ont ce savoir faire « INTITULE ».

    J’ai crée les relations dans la fenêtre relation.
    J’ai essayer de créer des formulaires, j’ai bien le menu déroulant et la zone de liste, mais cette zone de liste ne se met pas à jour de mon choix dans le menu déroulant !
    Est ce que je suis tout de même obligé de créer les jointures dans mon formulaire ? (si oui, est-ce dans la zone de liste, et quelle est la syntaxe ?)

    Où puis je trouver une BD exemple sur le net qui pourrais m’aider ?

    Merci

  2. #2
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Bonjour et bienvenue sur le forum,

    tu trouveras des cours entiers sur la recherche ici Développement d'interfaces graphiques

    Dolphy

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Août 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 88
    Points : 47
    Points
    47
    Par défaut pb de jointure ?
    Bonjour,

    ca ne marche toujours pas, malgrés mes modifications.

    dans mon formulaire j'ai une liste déroulante INTITULE que j'appelle Lst_INTITULE
    et une zone de liste que j'appelle lstResults
    et lblStats affiche le nombre de réponse.
    Mais voilà ma zone de liste ne change pas du tout après mon choix dans la liste déroulante

    Private Sub Lst_INTITULE_BeforeUpdate(Cancel As Integer)

    RefreshQuery

    End Sub




    Private Sub RefreshQuery()
    Dim SQL As String
    Dim SQLWhere As String


    'Je cherche à afficher le résultat de ma reque^te dans ma zone de liste suivant
    SQL = "SELECT EMPLOYE!ID_EMPLOYE, EMPLOYE!NOM_EMPLOYE FROM EMPLOYE, SAVOIRFAIRE, EMPSF Where INTITULE = '" & Me.Lst_intitule & "' "

    SQLWhere = Trim(Right(SQL, Len(SQL) - InStr(SQL, "Where ") - Len("Where ") + 1))

    SQL = SQL & ";"

    Me.lblStats.Caption = DCount("*", "EMPLOYE", SQLWhere) & " / " & DCount("*", "EMPLOYE")
    Me.lstResults.RowSource = SQL
    Me.lstResults.Requery

    End Sub
    Dans ma requête SQL, dois-je préciser ID_SAVOIRFAIRE et ID_EMPSF ?

    Merci

  4. #4
    Expert éminent
    Avatar de cafeine
    Inscrit en
    Juin 2002
    Messages
    3 904
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 3 904
    Points : 6 781
    Points
    6 781
    Par défaut
    Hello,

    effectivement aucune jointure entre tes tables ...

    commence par construire ta requête dans le QBE (mode interfacé) et seulement ensuite récupère le SQL.
    Ne mettez pas "Problème" dans vos titres, par définition derrière toute question se cache un problème
    12 tutoriels Access



  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Août 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 88
    Points : 47
    Points
    47
    Par défaut
    Voilà, j’ai fais une requête pour faire une jointure entre les tables. J’ai récupéré le code SQL que j’ai collé dans ma procédure.
    Mais quand je test mon formulaire, j’ai une erreur d’execution 2471, avec « l’objet ne contient pas d’automatisation ‘INTITULE’.


    De quoi s’agit-il ?


    Option Compare Database

    Private Sub Lst_intitule_BeforeUpdate(Cancel As Integer)
    RefreshQuery
    End Sub



    Private Sub RefreshQuery()
    Dim SQL As String
    Dim SQLWhere As String

    SQL = "SELECT SAVOIRFAIRE.ID_SAV AS SAVOIRFAIRE_ID_SAV, EMPSAV.ID_SAV AS EMPSAV_ID_SAV, EMPSAV.ID_EMP AS EMPSAV_ID_EMP, EMPLOYE.ID_EMP AS EMPLOYE_ID_EMP, EMPLOYE.NOM FROM SAVOIRFAIRE INNER JOIN (EMPLOYE INNER JOIN EMPSAV ON EMPLOYE.ID_EMP = EMPSAV.ID_EMP) ON SAVOIRFAIRE.ID_SAV = EMPSAV.ID_SAV WHERE INTITULE = '" & Me.Lst_intitule & "'"


    SQLWhere = Trim(Right(SQL, Len(SQL) - InStr(SQL, "Where ") - Len("Where ") + 1))

    SQL = SQL & ";"

    Me.lblStats.Caption = DCount("*", "EMPLOYE", SQLWhere) & " / " & DCount("*", "EMPLOYE")
    Me.lstResults.RowSource = SQL
    Me.lstResults.Requery

    End Sub


  6. #6
    Expert éminent
    Avatar de cafeine
    Inscrit en
    Juin 2002
    Messages
    3 904
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 3 904
    Points : 6 781
    Points
    6 781
    Par défaut
    Access voudrait savoir à quelle table appartient le champ INTITULE dont tu te sers dans la clause WHERE.
    Ne mettez pas "Problème" dans vos titres, par définition derrière toute question se cache un problème
    12 tutoriels Access



  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Août 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 88
    Points : 47
    Points
    47
    Par défaut Même erreur
    merci pour l'indication, mais j'ai toujours le même erreur "2471". Ai-je bien complété ma clause WHERE ?

    Private Sub Lst_intitule_BeforeUpdate(Cancel As Integer)
    RefreshQuery
    End Sub



    Private Sub RefreshQuery()
    Dim SQL As String
    Dim SQLWhere As String

    SQL = "SELECT SAVOIRFAIRE.ID_SAV AS SAVOIRFAIRE_ID_SAV, EMPSAV.ID_SAV AS EMPSAV_ID_SAV, EMPSAV.ID_EMP AS EMPSAV_ID_EMP, EMPLOYE.ID_EMP AS EMPLOYE_ID_EMP, EMPLOYE.NOM FROM SAVOIRFAIRE INNER JOIN (EMPLOYE INNER JOIN EMPSAV ON EMPLOYE.ID_EMP = EMPSAV.ID_EMP) ON SAVOIRFAIRE.ID_SAV = EMPSAV.ID_SAV WHERE SAVOIRFAIRE.INTITULE = '" & Me.Lst_intitule & "' "


    SQLWhere = Trim(Right(SQL, Len(SQL) - InStr(SQL, "Where ") - Len("Where ") + 1))

    SQL = SQL & ";"

    Me.lblStats.Caption = DCount("*", "EMPLOYE", SQLWhere) & " / " & DCount("*", "EMPLOYE")
    Me.lstResults.RowSource = SQL
    Me.lstResults.Requery

    End Sub

    Merci

  8. #8
    Membre du Club
    Profil pro
    Inscrit en
    Août 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 88
    Points : 47
    Points
    47
    Par défaut suite
    j'ai essayé avec des ( ) , des ! , des . et des [ ], mais je n'y arrive toujours pas !!!


    Y en a t-l d'autres ?


    Merci

Discussions similaires

  1. [AC-2010] Formulaire mis à jour avec liste déroulante
    Par wrdaniel dans le forum Access
    Réponses: 2
    Dernier message: 24/03/2013, 18h21
  2. [AC-2000] Formulaire de réservation avec liste déroulante
    Par julius870 dans le forum IHM
    Réponses: 1
    Dernier message: 05/09/2012, 19h27
  3. [ZF 1.11] critère de rechercher avec liste déroulante
    Par Invité dans le forum Zend_Form
    Réponses: 3
    Dernier message: 09/06/2011, 16h53
  4. critère de rechercher avec liste déroulante
    Par Invité dans le forum Zend Framework
    Réponses: 0
    Dernier message: 07/06/2011, 21h45
  5. Formulaire de résa avec liste déroulante
    Par mariepierre dans le forum Langage
    Réponses: 1
    Dernier message: 19/08/2009, 14h13

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