Précédent   Forum des professionnels en informatique > Logiciels > Microsoft Office > Access > IHM
IHM Ce forum est dédié aux questions relatives à la création de formulaires et d'états, avec ou sans code VBA, et macros.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 04/10/2011, 12h14   #1
Nom
Membre habitué
 
Inscription : octobre 2005
Messages : 528
Détails du profil
Informations forums :
Inscription : octobre 2005
Messages : 528
Points : 143
Points : 143
Par défaut MAJ d'une requête source pour un sous formulaire

Bonjour à tous
J'ai quelque difficulté à faire ce que je souhaiterai donc je viens vers vous

J'ai créé un formulaire avec un sous formulaire qui est un graphique croisé dynamique
Sur ce graphique j'affiche l'ensemble de mes commandes(mon appli est pour la vente de produit) sur une période donnée. Pour choisir cette période, j'ai mis dans le formulaire principale 2 contrôles de types calendrier

Je souhaiterai que lors du clic sur un bouton, avoir une mise à jour du graphique.
J'ai donc récupéré les dates, mis à jour la requête du sous formulaire (voir code ci dessous) puis utilisé la méthode requery mais en vain
Avez vous une explication ?

Dans le formulaire principale :
Code vba :
1
2
3
4
5
Private Sub SubmitAfficher_Click()
CurrentDb.QueryDefs("rqTest").sql = "SELECT NumCommande, SatutCommande FROM maTable " & _
"WHERE dateCommande BETWEEN #" & Format(CalendrierDebut.Value & " " & DateTime.Time, "mm/dd/yyyy hh:mm:ss") & " #  AND #" & Format(CalendrierFin.Value & " " & DateTime.Time, "mm/dd/yyyy hh:mm:ss") & "# " & _ 
"ORDER BY NumCommande;"
Me.Controls("Sous Formulaire").Form.Requery

j'ai vérifié la requête est correcte (je l'ai adapté pour le sujet donc ne vous fier pas au éventuelles erreurs) et me donne bien les valeurs attendu après avoir appuyé sur le bouton. Par contre le graphique lui ne bouge pas
__________________
Le savoir est une arme alors soyons armés
Nom est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/10/2011, 14h03   #2
Membre chevronné
 
Avatar de alassanediakite
 
Homme Alassane Diakité
Conseil - Consultant en systèmes d'information
Inscription : août 2006
Messages : 539
Détails du profil
Informations personnelles :
Nom : Homme Alassane Diakité
Âge : 34
Localisation : Mali

Informations professionnelles :
Activité : Conseil - Consultant en systèmes d'information

Informations forums :
Inscription : août 2006
Messages : 539
Points : 604
Points : 604
Envoyer un message via Yahoo à alassanediakite
Salut
J'ai tester le principe. Je pense que le formulaire ne voie pas les changements de la requête. Mais tu peux passer par...
Code :
1
2
3
4
5
6
7
Private Sub SubmitAfficher_Click()
Dim strsql as string
strsql = "SELECT NumCommande, SatutCommande FROM maTable " & _
"WHERE dateCommande BETWEEN #" & Format(CalendrierDebut.Value & " " & DateTime.Time, "mm/dd/yyyy hh:mm:ss") & " #  AND #" & Format(CalendrierFin.Value & " " & DateTime.Time, "mm/dd/yyyy hh:mm:ss") & "# " & _ 
"ORDER BY NumCommande;"
Me.Controls("Sous Formulaire").Form.RecordSource=strsql
Me.Controls("Sous Formulaire").Form.Requery
__________________
Le monde est trop bien programmé pour être l’œuvre du hasard…
alassanediakite est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/10/2011, 14h37   #3
Nom
Membre habitué
 
Inscription : octobre 2005
Messages : 528
Détails du profil
Informations forums :
Inscription : octobre 2005
Messages : 528
Points : 143
Points : 143
Merci pour ta réponse
Par contre, j'ai l'impression de perdre les informations de champs de filtre, de séries et de catégories. Du coup, le graphique est vide sauf si je replace manuelle ces informations mais il y a sûrement un moyen de les indiquer en VBA non ?
__________________
Le savoir est une arme alors soyons armés
Nom est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/10/2011, 15h11   #4
Membre chevronné
 
Avatar de alassanediakite
 
Homme Alassane Diakité
Conseil - Consultant en systèmes d'information
Inscription : août 2006
Messages : 539
Détails du profil
Informations personnelles :
Nom : Homme Alassane Diakité
Âge : 34
Localisation : Mali

Informations professionnelles :
Activité : Conseil - Consultant en systèmes d'information

Informations forums :
Inscription : août 2006
Messages : 539
Points : 604
Points : 604
Envoyer un message via Yahoo à alassanediakite
salut
Voir ici et
@+
__________________
Le monde est trop bien programmé pour être l’œuvre du hasard…
alassanediakite est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/10/2011, 09h18   #5
Nom
Membre habitué
 
Inscription : octobre 2005
Messages : 528
Détails du profil
Informations forums :
Inscription : octobre 2005
Messages : 528
Points : 143
Points : 143
Merci pour ces liens mais sauf si je n'ai pas compris, mon objet est un formulaire et non un MS Graph. non ?
__________________
Le savoir est une arme alors soyons armés
Nom est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/10/2011, 14h49   #6
Nom
Membre habitué
 
Inscription : octobre 2005
Messages : 528
Détails du profil
Informations forums :
Inscription : octobre 2005
Messages : 528
Points : 143
Points : 143
J'ai un début de réponse
En utilisant le ChartSpace, j'arrive à avoir le champs de séries par contre je ne trouve pas comment faire pour les autres. J’image que c'est une histoire de variable mais la documentation est réduite à ce sujet

Pour obtenir le champs de série voila la ligne ajoutée :
Code vba :
Me.Controls("Sous form").Form.ChartSpace.SetData chDimSeriesNames, chDataBound, "StatutCommande"

EDIT :
Pour les catégories et les valeurs, j'ai également trouvé :
Code vba :
1
2
Me.Controls("Sous form").Form.ChartSpace.SetData chDimCategories, chDataBound, "id"
Me.Controls("Sous form").Form.ChartSpace.SetData chConstants.chDimValues, chConstants.chDataBound, "durée"

Il me reste le champ de filtre à trouver ainsi que la manière de définir la fonction utilisée pour les valeurs afin de ne pas avoir la somme mais plutôt la moyenne
__________________
Le savoir est une arme alors soyons armés
Nom est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 04h05.


 
 
 
 
Partenaires

Hébergement Web