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 :

Changer de RecordSource d'un sous-formulaire [AC-2010]


Sujet :

IHM

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Points : 198
    Points
    198
    Par défaut Changer de RecordSource d'un sous-formulaire
    Bonjour à tous et merci comme toujours pour votre précieuse aide.
    Je trouve d’ailleurs que j'en ai un peu abusé ces derniers jours

    Alors me voici avec ce nouveau probléme.
    Un formulaire princiaple
    Un sous-formulaire qui quand ta lui change de RecordSource en fonction de la case à cocher.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Private Sub groupePrice_Click()
     
        Me.RecordSource = "SELECT ... "
     
    End Sub
    Dans le formulaire seul, tout fonctionne bien.

    Mais quand je retourne dans mon formulaire principale, ce même sous-formulaire agit différemment. A savoir que quand que je clique sur l'une des case à cocher, le sous-formulaire se vide de ces enregistrement.

    Et pas d'erreur.

    Merci à vous.

  2. #2
    Expert éminent
    Avatar de jimbolion
    Homme Profil pro
    Moulticien
    Inscrit en
    Janvier 2013
    Messages
    3 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Moulticien
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2013
    Messages : 3 150
    Points : 7 001
    Points
    7 001
    Billets dans le blog
    2
    Par défaut RecordSource
    Rifton007,

    Il n'y a aps de mal à abuser des bonnes choses

    Si l’évènement qui modifie le recordsource de ton sous formulaire est appliqué sur ton formulaire principal, c'est tout à fait normal (tu ne peux faire référence à me. qui modifie le recordSource de ton formulaire principal mais pas celui de ton SSF)

    tu dois passer le contrôle de ton sous formulaire

    Exemple

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Me.Form![MonSousFormulaire].Form.RecordSource = SQL_String
    JimBoLion

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Points : 198
    Points
    198
    Par défaut
    Il n'y a aps de mal à abuser des bonnes choses
    Merci, j'y manquerais pas à l'avenir
    J'ai pas encore fermer l'oeil de la nuit

    J'ai fait les modification préconisé, mais cela me génère une erreur.

    L’évènement est appliqué depuis le sous-formulaire pour le sous-formulaire.
    Donc utilisé Me. ne devrais pas poser de problème, même si par la suite je l'utilise comme sous-formulaire. Est c'est le cas, en solo ça fonctionne.

    Je dis peut être une connerie, mais ce problème aurait-il un lien avec le fait que mon formulaire principale et ce sous-formulaire soit lié par un champs pères/fils ?

  4. #4
    Expert confirmé Avatar de nico84
    Homme Profil pro
    Consultant/développeur ERP
    Inscrit en
    Mai 2008
    Messages
    3 108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant/développeur ERP
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 3 108
    Points : 5 231
    Points
    5 231
    Par défaut
    Bonjour,

    La case à cocher se trouve à quel niveau ?

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Points : 198
    Points
    198
    Par défaut
    Bonjour à toi,

    Il se trouve dans le pied du formulaire.

  6. #6
    Expert confirmé Avatar de nico84
    Homme Profil pro
    Consultant/développeur ERP
    Inscrit en
    Mai 2008
    Messages
    3 108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant/développeur ERP
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 3 108
    Points : 5 231
    Points
    5 231
    Par défaut
    Il y a plusieurs syntaxes, celle-ci devrait marcher :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Private Sub groupePrice_Click()
     
        forms("nomdusousformulaire").RecordSource = "SELECT ... "
     
    End Sub
    Il faut que dans le select il y ait le fils sinon ça fait peut-être une erreur...

  7. #7
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Points : 198
    Points
    198
    Par défaut
    Cela n'a pas fonctionné, nous avons déjà explorer cette piste en début de post.

    Au chargement du formulaire principale, cela ne pose aucun problème.
    Car les champs père/fils sont paramétré dans les propriété Access.

    Donc surement que je casse le liens père/fils avec mon SELECT vba.
    Comment faire un lien père/fils en VBA?

    Je met ma requête SQL, on ne sait jamais.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Me.RecordSource = "
    SELECT contentOfPack.ID, contentOfPack.quantity, listOfPerfume.perfume, listOfPerfume.price1, " & _
    "listOfPerfume.price2, listOfPerfume.price3, contentOfPack.id_pack, [price" & Me.groupePrice.Value & "]-([price" & Me.groupePrice.Value & "]/100*[marginPrice]) " & _
    "AS [prix de vente unité], [prix de vente unité]*[quantity] AS [Prix de vente lot]" & _
     
    "FROM listOfPack INNER JOIN (listOfPerfume INNER JOIN contentOfPack ON listOfPerfume.ID = " & _
    "contentOfPack.[id_perfume]) ON listOfPack.ID = contentOfPack.id_pack ORDER BY contentOfPack.ID;"

  8. #8
    Expert confirmé Avatar de nico84
    Homme Profil pro
    Consultant/développeur ERP
    Inscrit en
    Mai 2008
    Messages
    3 108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant/développeur ERP
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 3 108
    Points : 5 231
    Points
    5 231
    Par défaut
    Je vois mal ce que Me.groupePrice.Value fait dans la requête alors que c'est une case à cocher !?

    Par ailleurs l'existence d'un lien pere/fils n'interdit pas de modifier le recordsource... Mais dans certains cas complexes il peut être plus clair de supprimer ce lien et de mettre toutes les contraintes dans le recordsource.

  9. #9
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Points : 198
    Points
    198
    Par défaut
    Bonjour et merci

    Alors j'ai trois colonnes, trois prix de référence.
    Price1 price2 et price 3, le value du groupe option intervient pour le choix du prix de référence sur le quel je fais un calcul par la suite.

    Aussi ce sous-formulaire et son formulaire parent sont lié par ce lien père/fils.
    Si non, impossible d'afficher le contenue du sous-formulaire approprié à son formulaire parent. Je sais pas si j'ai été clair, mais j'ai fais de mon mieux

    Donc si j'ai compris au stade actuel, on c'est pas d'ou vient le problème ?

  10. #10
    Expert confirmé Avatar de nico84
    Homme Profil pro
    Consultant/développeur ERP
    Inscrit en
    Mai 2008
    Messages
    3 108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant/développeur ERP
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 3 108
    Points : 5 231
    Points
    5 231
    Par défaut
    Citation Envoyé par Rifton007 Voir le message
    Aussi ce sous-formulaire et son formulaire parent sont lié par ce lien père/fils.
    Lequel ?

    Tu dis plus haut que groupeprice se trouve dans le pied du formulaire mais ne serais-ce pas plutot dans le pied du sous-formulaire ? Ce serait plus cohérent avec le contenu du select...

    Si je comprend bien c'est une liste à cocher qui peut prendre les valeurs 1 2 ou 3 donc cela ne me semble pas adapté pour faire un lien père/fils. Comme dit + haut il vaut mieux mettre toutes les contraintes dans le recordsource !

  11. #11
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Points : 198
    Points
    198
    Par défaut


    Voila un wireframe pour mieux comprendre ce que je tente de réaliser.

    Petite explication
    Table contenue des lots, affiche produits du lot en cours dans le formulaire principale.

  12. #12
    Expert confirmé Avatar de nico84
    Homme Profil pro
    Consultant/développeur ERP
    Inscrit en
    Mai 2008
    Messages
    3 108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant/développeur ERP
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 3 108
    Points : 5 231
    Points
    5 231
    Par défaut
    Désolé je ne vois pas ce qui permet d'affecter une valeur à groupeprice...

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

Discussions similaires

  1. Probleme affichage avec recordsource dans un sous formulaire
    Par tamalkasi dans le forum VBA Access
    Réponses: 2
    Dernier message: 05/08/2010, 15h08
  2. [AC-2003] Changer le RecordSource d'un sous formulaire
    Par Goupo dans le forum IHM
    Réponses: 2
    Dernier message: 07/04/2010, 10h59
  3. Changer la source d'un sous formulaire en mode continu
    Par jmde dans le forum VBA Access
    Réponses: 1
    Dernier message: 06/07/2008, 18h14
  4. Changer Source Objet d'un sous-formulaire
    Par vandrie dans le forum IHM
    Réponses: 6
    Dernier message: 28/11/2007, 14h48
  5. changer la source d'un sous-formulaire
    Par ac264 dans le forum IHM
    Réponses: 5
    Dernier message: 11/10/2007, 22h57

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