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

Requêtes et SQL. Discussion :

[A-07] Requete relative à un autre sous-formulaire


Sujet :

Requêtes et SQL.

  1. #1
    Membre régulier Avatar de AlainL
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    178
    Détails du profil
    Informations personnelles :
    Âge : 74
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2008
    Messages : 178
    Points : 90
    Points
    90
    Par défaut [A-07] Requete relative à un autre sous-formulaire
    Bonjour

    J'ai
    - un formulaire principal,
    - comprenant 4 sous-formulaires organisés en onglets.

    Dans le 2ème sous-form, cela me gère les enregistrements relatifs à une adresse de livraison, là pas de problème.

    Mais le 3ème sous formulaire comporte une zone de liste déroulante, qui devrait me reprendre celle du sous-form N° 2.

    Je n'arrive pas à trouver la bonne solution, que je tente de coder dans la partie SQL de cette liste déroulante. Les tables de cette requete sont la table principale, et la sous-table 2:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT  ... les champs...
     
    FROM MaTable1 INNER JOIN MaTable2 ON Table1ID = IDTable1DansTable2
     
    ORDER BY .....;
    Cela me donne à chaque fois la liste de l'ensemble de la table 2, au lieu de souhaité uniquement celle concernant le ID sélectionné dans la table 1.

    Merci de votre aimable aide.

  2. #2
    Rédacteur/Modérateur
    Avatar de loufab
    Homme Profil pro
    Entrepreneur en solutions informatiques viables et fonctionnelles.
    Inscrit en
    Avril 2005
    Messages
    12 029
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Entrepreneur en solutions informatiques viables et fonctionnelles.
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2005
    Messages : 12 029
    Points : 24 584
    Points
    24 584
    Par défaut
    Bonjour,

    Si j'ai bien compris tu souhaites utiliser l'élément choisi d'une liste présente dans un sous-formulaire pour alimenter le critère d'une requète présente dans un autre sous-formulaire ?

    Si c'est cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Select .... FROM ... WHERE monchamp = FORMS.monform.monsousform.FORM.maliste
    En majuscule ce sont les mots clefs le reste est a remplacer par les vrais noms de formulaire et de controle.

    Note qu'il faut initialiser ta zone liste car si tu vas faire un tour sur le sous-form avant d'être passé par la zone liste tu n'auras rien d'afficher... au pire une erreur.

    Sur ma page il y a un tuto qui devrait t'interresser, celui sur les appels interformulaire.

    Cordialement,

  3. #3
    Membre régulier Avatar de AlainL
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    178
    Détails du profil
    Informations personnelles :
    Âge : 74
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2008
    Messages : 178
    Points : 90
    Points
    90
    Par défaut
    Merci bien Loufab, vais tester cela

  4. #4
    Membre régulier Avatar de AlainL
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    178
    Détails du profil
    Informations personnelles :
    Âge : 74
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2008
    Messages : 178
    Points : 90
    Points
    90
    Par défaut
    Heu...

    Dans le MonSousForm de ton instruction, la Source est la requete automatiquement générée lors de l'inclusion de ce sous-form.

    Seulement, dans le tag Autres concernant ce sous-formulaire, il ne comprte pas de nom permettant de l'adresser directement (pour remplacer MaListe).

    Select .... FROM ... WHERE monchamp = FORMS.monform.monsousform.FORM.maliste
    J'ai donc tenté d'atteindre depuis le tag Données:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Select .... FROM ... WHERE monchamp = FORMS.monform.monsousform.FORM.Recordset
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Select .... FROM ... WHERE monchamp = FORMS.monform.monsousform.FORM.Source
    sans succès. Comment adresser ce champ là ?

    Merci

  5. #5
    Rédacteur/Modérateur
    Avatar de loufab
    Homme Profil pro
    Entrepreneur en solutions informatiques viables et fonctionnelles.
    Inscrit en
    Avril 2005
    Messages
    12 029
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Entrepreneur en solutions informatiques viables et fonctionnelles.
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2005
    Messages : 12 029
    Points : 24 584
    Points
    24 584
    Par défaut
    Apparemment j'ai pas compris ton besoin. Peux-tu être plus explicite ?

    Qu'est-ce que tu alimentes, avec quoi, quel filtre et ou ils sont placé ?

    J'ai beau relire, toujours pas compris

    Cordialement,

  6. #6
    Membre régulier Avatar de AlainL
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    178
    Détails du profil
    Informations personnelles :
    Âge : 74
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2008
    Messages : 178
    Points : 90
    Points
    90
    Par défaut
    Bonjour Loufab

    Une p'tite photo sera probablement plus parlante , désolé:

    SForm1: Sur ce sous-formulaire, il y a dans cet exemple 2 enregistrements (onglet Adr.Livr.). Le filtre ici est placé au niveau du formulaire lui-même.

    SForm2: (Onglet Commande) Le champ entouré en rouge est la zone de liste qui devrait me reprendre, sous forme de liste déroulante, la liste des enregistrements actuellement disponibles dans SForm1 (2 dans cet exemple). La requete que je n'arrive pas à faire est dans le champ Données/Contenu.

    Ce que je n'arrive pas à faire:

    Créer dans la zone Contenu de cette liste déroulante la requete qui lui exprime:
    - va me chercher les enregistrements (le recordset) contenus dans le SForm1- affiche les moi en liste déroulante
    - uniquement ceux-ci
    - ou une ligne blanche s'il n'y a pas d'enregistrement.

    A tout hasard, j'ai joint l'articulation et les liaisons de ma BD.

    Est-ce plus clair ?

  7. #7
    Rédacteur/Modérateur
    Avatar de loufab
    Homme Profil pro
    Entrepreneur en solutions informatiques viables et fonctionnelles.
    Inscrit en
    Avril 2005
    Messages
    12 029
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Entrepreneur en solutions informatiques viables et fonctionnelles.
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2005
    Messages : 12 029
    Points : 24 584
    Points
    24 584
    Par défaut
    En effet rien à voir avec ce que j'ai compris.

    Dans un premier temps il faut créer la source pour la zone liste.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Select .... FROM LIV WHERE LIV_ID = forms.monform.CLI_ID;
    ou monform est le nom du formulaire principal et donc forms.nomform.CLI_ID est le champ identifiant client.

    Après vérification ça devrait déjà s'afficher.

    Ensuite il faut prévoir le raffraichissement en toutes circonstances de cette liste.

    Dans l'événement Sur Activation du formulaire principal faire un

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    me.monsousform.form.maliste.requery
    Ceci devrait être suffisant. Peut-être que j'ai oublié des cas, mais je ne pense pas.

    Cordialement,

  8. #8
    Membre régulier Avatar de AlainL
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    178
    Détails du profil
    Informations personnelles :
    Âge : 74
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2008
    Messages : 178
    Points : 90
    Points
    90
    Par défaut
    Ah, merci Loufab, cette fois, j'ai compris

    En te souhaitant de très joyeuse fêtes... ailleurs que sur un ordinateur

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 26/08/2006, 15h55
  2. Réponses: 7
    Dernier message: 24/07/2006, 15h11
  3. Réponses: 10
    Dernier message: 02/02/2006, 10h42
  4. Lien sous-formulaire à un autre sous-formulaire
    Par jehhej dans le forum Access
    Réponses: 4
    Dernier message: 25/01/2006, 08h05
  5. requete lié a un sous formulaire
    Par philo71 dans le forum IHM
    Réponses: 27
    Dernier message: 27/11/2005, 22h53

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