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

IHM Discussion :

Pb Formulaire avec liste déroulante


Sujet :

IHM

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 20
    Points : 7
    Points
    7
    Par défaut Pb Formulaire avec liste déroulante
    Bonjour,

    j'ai deux tables Catégorie et Sous catégorie.

    Je souhaite créer un formulaire avec une liste déroulante (des catégories) qui génère une fois un choix effectué une autre liste déroulante (des sous-catégories correspondantes).

    1) Choix d'une catégorie dans une liste déroulante générée à partir de la table correspondante
    2) Liste déroulante avec les données des sous-catégorie de la catégorie.

    Au final je dois récupérer la valeur de la sous-catégorie sélectionnée pour un autre traitement.

    Je n'arrive pas à créer cela à partir de l'assistant. Qqun peut-il m'aider ?

  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

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 20
    Points : 7
    Points
    7
    Par défaut
    Merci pour la fonction.

    J'ai maintenant un autre problème.

    La première liste charge bien ses éléments. Une fois un choix effectué, tous les champs sous-catégories apparaissent (ils apparaissent dès le départ d'ailleurs).
    Si je tente de restreindre l'affichage seulement des sous-catégories de la catégorie sélectionnée comme ceci :

    ....
    SELECT sous_categorie.id_sscategorie, sous_categorie.nom_sous_categorie
    FROM categories INNER JOIN sous_categorie ON categories.num_categorie = sous_categorie.id_categorie WHERE (((sous_categorie.id_categorie)=[Formulaires]![rela_piece_categorie]![Modifiable12].[AprèsMAJ])) ORDER BY sous_categorie.nom_sous_categorie;
    ...

    plus aucune valeur n'apparaît dans les sous-catégories.

    Modifiable12 correspond à la première liste.

    Merci d'avance pour votre aide.

  4. #4
    Membre habitué Avatar de Orakle
    Homme Profil pro
    Responsable Informatique
    Inscrit en
    Mars 2004
    Messages
    204
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Responsable Informatique
    Secteur : Transports

    Informations forums :
    Inscription : Mars 2004
    Messages : 204
    Points : 154
    Points
    154
    Par défaut
    Salut !


    Où as tu mis ton select ?

    je pense que ton est superflu derrière
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    [Modifiable12].[AprèsMAJ]
    Ton select dois venir sur la "Propriété" Après MAJ de ta 1ere ListeModifiable


    Enfin je peux me tromper

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 20
    Points : 7
    Points
    7
    Par défaut
    J'ai tout repris à 0. j'arrive presque au résultat souhaité.
    J'ai par contre un nouveau pb.

    Ma première liste charge bien ses éléments (nom_categorie).
    Par contre, une fois un choix effectué j'ai une erreur en ouvrant la deuxième liste des sous-catégories. En effet, la fonction Filtre charge le nom de la catégorie et non pas l'id :

    ...
    Private Sub CHAMP1_AfterUpdate()
    nom_sous_categorie.RowSource = "Select id_sscategorie,num_sscategorie,nom_sous_categorie From sous_categorie " & _
    "where id_categorie= " & CHAMP1 & ";"
    nom_sous_categorie.Requery

    End Sub
    ...

    Le message dit : "id_categorie=Categorie1".

    Les caractéristiques de CHAMP1 (liste des catégories) sont :
    Données :
    - source controle : nom_categorie
    - contenu : SELECT categories.nom_categorie FROM categories;

    Je n'arrive donc pas à afficher le nom dans la liste mais que ce soit la clé qui soit utilisée pour le filtre sur la deuxième liste.

    Merci d'avance pour votre aide.

  6. #6
    Membre éprouvé
    Avatar de keita
    Homme Profil pro
    Inscrit en
    Novembre 2002
    Messages
    881
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations forums :
    Inscription : Novembre 2002
    Messages : 881
    Points : 1 121
    Points
    1 121
    Par défaut
    ton code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Private Sub CHAMP1_AfterUpdate() 
    nom_sous_categorie.RowSource = "Select id_sscategorie,num_sscategorie,nom_sous_categorie From sous_categorie " & _ 
    "where id_categorie= " & CHAMP1 & ";" 
    nom_sous_categorie.Requery 
    End Sub
    1/erreur dans
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    where id_categorie= " & CHAMP1 & ";"
    car id_categorie n'est pas un champ de select..... ça devait plutot etre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    where id_sscategorie= " & CHAMP1 & ";"
    2/
    Les caractéristiques de CHAMP1 (liste des catégories) sont :
    Données :
    - source controle : nom_categorie
    - contenu : SELECT categories.nom_categorie FROM categories;
    change le contenu:
    SELECT categories. id_categorie, categories.nom_categorie FROM categories

  7. #7
    Futur Membre du Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 20
    Points : 7
    Points
    7
    Par défaut
    Merci pour ton aide mais :

    1) Erreur dans :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    where id_categorie= " & CHAMP1 & ";"
    --> en fait id_categorie est la clé étrangère dans la liste sous_categorie. Il s'agit bien de ce champ qui doit servir pour le filtre.

    2)
    change le contenu:
    SELECT categories. id_categorie, categories.nom_categorie FROM categories
    --> en faisant cela ce sont les id qui s'affichent dans la liste Categorie et non pas le nom. Par contre, le filtre du coup fonctionne et ce sont les sous-categories correspondantes qui sont affichées (même si ce devrait être le nom).

    Je sèche.

  8. #8
    Membre actif Avatar de samlepiratepaddy
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    320
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 320
    Points : 217
    Points
    217
    Par défaut
    Stl,
    --> en faisant cela ce sont les id qui s'affichent dans la liste Categorie et non pas le nom. Par contre, le filtre du coup fonctionne et ce sont les sous-categories correspondantes qui sont affichées (même si ce devrait être le nom).
    juste une question dans ta liste déroulante de "masquer" la première colonne !
    Largeur colonne--->0cm;2.5cm
    !Cela masquera la première colonne et fera apparaitre la seconde qui est le nom !
    @+
    La connaissance ne vaut que si elle est partagée par tous et pour tous!
    Access et moi c'est mais en fait on s' bien !
    Ps: Je comprend très vite quand on m'explique longtemps !!

  9. #9
    Futur Membre du Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 20
    Points : 7
    Points
    7
    Par défaut
    Un grand merci. Je connaissais pas cette notion de colonne...

    Au niveau du choix dans les deux listes tout fonctionne correctement maintenant. Juste un dernier pb.

    Une fois la sous_categorie sélectionnée, le résultat se couple avec un autre id (ref_piece) déjà présent dans le formulaire et le tout est stocké dans une table.

    Table rela_categorie_piece :
    - id_rela : la clé primaire
    - ref_piece : l'id de la piece
    - ref_sscategorie : l'id de la sous_categorie

    L'opération se passe correctement. La table rela_categorie_piece se remplit correctement. Sauf que lors du choix dans la liste sous_categorie, de nouveaux champs sont créés dans les tables Categorie et Sous Categorie avec les valeurs sélectionnées dans chacune des listes.
    Et c'est l'id du nouveau champ sous_categorie qui est stocké dans la table rela_categorie_piece.

    Comment puis-je configurer les élements afin de ne récupérer que l'id de la sous_categorie pour le stocker dans la table des relations (et donc ne pas créer de nouveaux champs...).

  10. #10
    Membre actif Avatar de samlepiratepaddy
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    320
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 320
    Points : 217
    Points
    217
    Par défaut
    Citation Envoyé par Rouanou
    Un grand merci. Je connaissais pas cette notion de colonne...

    Au niveau du choix dans les deux listes tout fonctionne correctement maintenant. Juste un dernier pb.

    Une fois la sous_categorie sélectionnée, le résultat se couple avec un autre id (ref_piece) déjà présent dans le formulaire et le tout est stocké dans une table.

    Table rela_categorie_piece :
    - id_rela : la clé primaire
    - ref_piece : l'id de la piece
    - ref_sscategorie : l'id de la sous_categorie

    L'opération se passe correctement. La table rela_categorie_piece se remplit correctement. Sauf que lors du choix dans la liste sous_categorie, de nouveaux champs sont créés dans les tables Categorie et Sous Categorie avec les valeurs sélectionnées dans chacune des listes.
    Et c'est l'id du nouveau champ sous_categorie qui est stocké dans la table rela_categorie_piece.

    Comment puis-je configurer les élements afin de ne récupérer que l'id de la sous_categorie pour le stocker dans la table des relations (et donc ne pas créer de nouveaux champs...).
    Heu, je comprend pas trop???
    je pense que tu confonds Champ avec lignes !!!!
    Mais je ne comprend pas trop tu peux rexepliquer Stp...
    La connaissance ne vaut que si elle est partagée par tous et pour tous!
    Access et moi c'est mais en fait on s' bien !
    Ps: Je comprend très vite quand on m'explique longtemps !!

  11. #11
    Futur Membre du Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 20
    Points : 7
    Points
    7
    Par défaut
    Tu as raison j'utilisais les mauvais termes.

    Les deux liste Categorie et Sous categorie me permettent de récupérer un id (de la sous_categorie) que je stocke avec un autre id (d'une piece) dans une table Rela_categorie_piece.

    Les éléments des listes ont déjà été créés précédemment. Il y a juste un choix à effectuer.

    Le pb est qu'actuellement, après avoir sélectionné la catégorie, puis la sous_categorie, une nouvelle ligne est créé dans la table Categorie (avec la valeur de sélection dans la liste) et une nouvelle ligne est créé dans sous_categorie (idem). Le stockage dans la table Rela_categorie_piece s'effectue lui correctement mais avec la valeur de l'id_sscategorie de la nouvelle ligne.

    Je veux simplement que le choix de la categorie, puis de la sous_categorie me donne l'id_sscategorie que je stocke ensuite avec l'id de la piece dans la table Rela_categorie_piece.

    Je ne sais pas si je suis plus clair...

  12. #12
    Futur Membre du Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 20
    Points : 7
    Points
    7
    Par défaut
    Quelqu'un a-t-il une idée ?

  13. #13
    Futur Membre du Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 20
    Points : 7
    Points
    7
    Par défaut
    Autre chose :

    La procédure
    http://access.developpez.com/sources...s#FiltrerListe

    me pose pb.

    Lorsque je sélectionne une catégorie, puis une sous-catégorie tout fonctionne correctement.
    Cela se gâte au deuxième enregistrement, lorsque je sélectionne une categorie, la sous-categorie de l'enregistrement précédent se réinitialise.

    Comment puis-je éviter cela ?

Discussions similaires

  1. Formulaire avec liste déroulante
    Par Freedom00 dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 20/09/2007, 08h18
  2. Réponses: 2
    Dernier message: 07/09/2007, 13h33
  3. Lenteur de formulaires avec listes déroulantes
    Par olese dans le forum InfoPath
    Réponses: 1
    Dernier message: 27/08/2007, 08h25
  4. formulaire avec liste déroulante
    Par catmor dans le forum Modélisation
    Réponses: 1
    Dernier message: 21/06/2007, 19h18
  5. Recherche formulaire avec liste déroulante
    Par kimar dans le forum Access
    Réponses: 2
    Dernier message: 28/07/2006, 12h02

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