ACCESS : LES SOUS-FORMULAIRES
Avant de commencer
Access vous offre plusieurs types de formulaires. Ce cours vous montre comment créer et utiliser un formulaire dans un formulaire. Pour plus d'informations sur les formulaires en général, veuillez vous référer au cours sur les formulaires.
On présume que vous savez comment créer des requêtes qui incluent des champs calculés.
Il est très important que les relations entre les tables soient réalisées pour qu'il y ait un lien entre le formulaire et le sous formulaire sur un champ en commun.
Dans le cas étudié, il s'agit du champ fact_id de la table Facture et du champ fact_id de la table L_Fact_Art.
Les champs de plusieurs tables et requêtes seront requis pour réaliser l'exercice de ce cours.
Introduction
Pour vraiment utiliser une base de données, il faut être capable de chercher et d'afficher des données provenant de plusieurs tables. Cela veut souvent dire qu'il faut un formulaire principal, qui inclut les informations générales, avec un ou des sous formulaires pour avoir plus de détails.
L'exercice de ce cours consiste à créer un formulaire pour la facturation de l'entreprise. Pour afficher toutes les informations que ce genre de formulaire contient, il devra contenir un second formulaire qui décrira les items facturés.
Mais avant de pouvoir créer ce formulaire, vous devez avoir effectué les exercices précédents. Ainsi les tables sont créés et possèdent des données. Vos tables sont reliés et vous êtes capable de créer des requêtes avec des champs calculés. Assurez-vous de bien maîtriser ces concepts avant de créer un formulaire qui inclut un sous-formulaire.
La création d'un formulaire de facturation se fait par étapes :
- Création des requêtes nécessaires.
- Création du formulaire.
- Modification du formulaire pour qu'il soit plus présentable.
- Ajout du sous-formulaire.
- Calcul du total de la facture dans le sous-formulaire.
- Ajout du champ calculé dans le formulaire principal.
Création des requêtes nécessaires
Avant de pouvoir créer le formulaire et un sous-formulaire, il faut déterminer quels seront les champs requis et dans quel formulaire ils vont se retrouver.
Pour la facture, il faut les informations des tables Facture et Client. Il faut aussi ajouter dans le sous-formulaire les informations de la table L_Fact-Art ainsi que la description du produit et de son prix unitaire qui se retrouve dans la table Article.
Vous devez créer deux requêtes: l'une avec les champs requis pour la facture et l'autre sur les items de cette facture. Nous regarderons ensuite comment avoir le total de cette facture.
- Du menu Créer, sélectionnez le bouton Création de requête .
- De la liste des tables, sélectionnez les tables Client et Facture.
- Cliquez sur le bouton .
- De la liste des champs de la table Facture, sélectionnez tous les champs dans le même ordre.
- De la liste des champs de la table Client, sélectionnez les champs cli_nom, cli_adresse, cli_ville et cli_code_postal.
- Enregistrez cette requête sous le nom RFacture.
- Fermez la requête.
Créez une seconde requête.
- Du menu Créer, sélectionnez le bouton Création de requête .
- De la liste des tables, sélectionnez les tables L_Fact-Art et Article.
- Cliquez sur le bouton .
Puisque les relations entre les tables ont déjà été établies, vous devriez voir un lien entre les champs art_id de la table L_Fact-Art et le champ art_id de la table Article. Sinon, il faudra faire la relation entre ces deux champs.
- De la liste des champs de la table L_Fact-Art, sélectionnez tous les champs.
Vous pouvez aussi sélectionnez l'astérisque (*) au dessus de la liste des champs. Cela aura l'effet de choisir tous les champs de la table.
- De la liste des champs de la table Article, sélectionnez les champs art_nom et art_pu.
- Créez un champ calculé STotal: [art_qte]*[art_pu]
N'oubliez pas de mettre les crochets autour du champ art_pu. Access se chargera de mettre les crochets autour de art_qte. Ce champ calculé va donner le total de chacun des items de la facture. On regardera plus loin comment avoir le total de tous les items de la facture.
Les majuscules ne sont pas nécessaires, Access n'est pas sensible à la casse.
- Enregistrez cette requête sous le nom RFacture-Items.
- Fermez la requête.
Création du formulaire
Avant de pouvoir ajouter un sous-formulaire, il faut créer le formulaire principal. Celui-ci affichera les informations générales de la facture. Les informations sur les détails de la facture seront dans le sous-formulaire.
- Du menu Créer, sélectionnez le bouton Assistant Formulaires .
- Sélectionnez la source du formulaire qui sera la requête RFacture.
- Sélectionnez tous les champs de la requête en appuyant sur le bouton .
- Cliquez sur le bouton .
L'assistant constate qu'il peut trier les enregistrements selon la clé primaire cli_id ou par la clé primaire fact_id. Il vous demande par quel champ il doit trier les enregistrements. Pour cet exemple, on veut afficher les informations par facture et non par client.
- Sélectionnez par Facture.
- Cliquez sur le bouton .
L'assistant vous demande ensuite de choisir le type de présentation des champs.
- Sélectionnez l'option Colonne simple.
- Cliquez sur le bouton .
L'assistant vous demande pour terminer le nom que vous souhaitez donner au formulaire.
- Saisissez Facture.
- Cliquez sur le bouton .
Voici le résultat :
Modification du formulaire
Le formulaire est terminé. Mais il n'y a pas assez d'espace pour le sous-formulaire. La prochaine partie consiste à modifier le formulaire ci-dessus pour y inclure un sous formulaire.
- Passez en Mode création en appuyant sur le bouton .
Au besoin, vous pouvez changer les dimension du formulaire, en plaçant le pointeur sur la bordure du formulaire, puis lorsque le pointeur changera de forme, restez appuyé sur le bouton gauche de la souris et étirez le formulaire vers l'extérieur.
Ajouter le sous-formulaire
Il y a maintenant assez d'espace pour voir les items de la facture ainsi que le total. La prochaine partie consiste à créer le sous-formulaire.
- Du menu Création, sélectionnez le bouton Sous-Formulaire , puis cliquez dans le formulaire.
L'assistant pour les sous-formulaires va vous demander quel sera la source du sous-formulaire. Est-ce une table, une requête ou un formulaire que vous avez déjà préparé.
- Sélectionnez l'option Utiliser les tables et les requêtes existantes.
- Cliquez sur le bouton .
L'assistant vous demande ensuite quels seront les champs qui seront inclus dans le formulaire.
- De la liste des tables et des requêtes, sélectionnez la requête RFacture-Items.
- Sélectionnez tous les champs de la requête en appuyant sur le bouton .
- Cliquez sur le bouton .
L'assistant vous demande quels seront les champs en commun entre le formulaire et le sous-formulaire.
Pour cet exercice, nous allons laisser Access trouver les champs en communs.
Si cela ne fonctionne pas, vous verrez à la fin comment déterminer la relation père-fils entre le formulaire et le sous-formulaire.
- Sélectionnez l'option Choisir à partir d'une liste.
Si vous sélectionnez l'option Les définir moi-même, vous devrez aussi déterminer quels sont les champs en commun entre le formulaire et le sous-formulaire.
- Pour le champ en commun du formulaire, sélectionnez le champ fact_id.
- Pour le champ en commun du sous-formulaire, sélectionnez le champ fact_id.
Vous aviez le choix entre laisser l'assistant trouver les champ en commun ou les déterminer par vous-même. Le reste des opérations pour terminer le sous-formulaire sont les mêmes.
- Cliquez sur le bouton .
- Laissez le nom du sous-formulaire à RFacture-Items sous-formulaire.
- Cliquez sur le bouton .
Le sous-formulaire est maintenant inclus.
- Passez au Mode formulaire en appuyant le bouton .
À moins qu'on ne l'indique autrement, la présentation des données se fait toujours en mode feuille de données comme dans les tables ou les requêtes.
Il se peut qu'une boite de dialogue vous demande une quantité, cliquez simplement sur le bouton OK.
Le total de la facture
Le formulaire montre maintenant les informations du formulaire ainsi que les items facturés. Mais il ne montre pas le total de la facture. Il faut ajouter un champ calculé pour le voir. La prochaine partie consiste à ajouter un champ calculé pour voir le total.
- Retournez en Mode création en appuyant sur le bouton .
Il faut ajouter un champ calculé dans l'en-tête ou le pied de ce sous-formulaire. Pour cet exemple, il sera ajouté dans le pied de formulaire.
Pour agrandir le pied de formulaire :
- Placez le pointeur au bas de la barre Pied de formulaire.
Le pointeur devrait changer de forme.
- En restant appuyé sur le bouton gauche de la souris, déplacez le pointeur vers le bas.
La zone du pied de formulaire va s'agrandir. Il faut qu'il soit assez grand pour ajouter un champ calculé.
- De la barre d'outils, cliquez sur le bouton zone de texte .
- Cliquez dans la zone du pied de formulaire.
Un champ vide va apparaître dans le pied de formulaire. Il faut maintenant ajouter la formule pour calculer le total et lui donner un nom significatif.
- Cliquez une première fois sur le nouveau champ pour le sélectionner.
- Cliquez une seconde fois dans le champ, pour pouvoir écrire la formule requise.
- Écrivez la formule suivante : =somme(Stotal).
- Cliquez ensuite dans l’étiquette du champ et nommez-la Total :
- Appuyez sur la touche .
Comme dans Excel, les formules des champs calculés que l'on retrouve dans des formulaires ou des états commencent toujours avec le signe « = ». Cette formule va additionner les valeurs de tous les enregistrements STotal.
Il faut maintenant donner un nom significatif à ce nouveau champ calculé.
- Placez le pointeur sur le nouveau champ.
- Cliquez sur le bouton droit de la souris.
- Du menu contextuel, sélectionnez l'option Propriétés.
- Changez le contenu de la case Nom à TotalItems.
Puisque ce champ a été placé soit dans l'en-tête ou le pied du formulaire, il va maintenant faire la somme de tous les enregistrements de la table ou de la requête. Si ce même champ avait été placé dans la zone détail, il aurait fait la somme que d'un seul enregistrement. C'est pour cette raison qu'il était important de placer ce champ dans l'en-tête ou le pied du formulaire. Ces zones permettent d'accomplir des opérations sur tous les enregistrements au lieu d'un seul.
Ajouter le calcul du sous-formulaire dans le formulaire principal
Dans l'exercice précédent, nous avons ajouté un champ appelé TotalItems qui fait le total de tous les enregistrements. Il suffit maintenant de l'ajouter au formulaire Facture pour afficher le total.
Nous sommes maintenant de retour au formulaire Facture. Il faut ajouter une référence au champ TotalItems dans ce formulaire pour voir le total des items de cette facture.
- Ajoutez un champ en dessous du sous-formulaire en appuyant sur le bouton .
- Cliquez avec le bouton droit de la souris sur le nouveau champ.
- Du menu contextuel, sélectionnez l'option Propriétés.
- Placez le pointeur dans .
- Cliquez sur le bouton à la droite de la case.
Cela va activer le générateur d'expression. Il faut spécifier à Access l'endroit où se trouve le champ TotalItems. Ce champ se retrouve dans le formulaire RFacture_items sous-formulaire.
- Dans la zone de gauche, cliquez sur le dossier Facture, puis RFacture_items sous-formulaire.
- Dans la zone Catégories d'expressions, double-cliquez sur le champ TotalItems.
- Cliquez sur le bouton .
- Renommez le texte du champ en : Total.
- De la barre d'outils, cliquez sur le bouton .
- Du menu Affichage, sélectionnez l'option Mode formulaire.
Le total est bien là. Mais va-t-il se mettre à jour si on change une valeur ?
- Placez le pointeur dans la case quantité de la dernière ligne du sous formulaire.
- Changez la quantité vendue de 3 à 4.
- Déplacez le pointeur vers le haut.
Le total du formulaire se met à jour lorsque vous changez d'enregistrement.
Les relations père-fils
Il est possible que la relation entre le formulaire et le sous-formulaire ne se fasse pas. Mais vous pouvez toujours déterminer quels sont les champs en commun entre les deux tables. Le champ père est un champ qui provient du formulaire principal. Le champ fils est l'un qui se retrouve dans le sous-formulaire.
- Sélectionnez le formulaire Facture.
- Passez en Mode création en appuyant sur le bouton .
- Du menu Affichage, sélectionnez l'option Mode création.
- Sélectionnez le sous-formulaire.
- Cliquez sur le bouton droit de la souris.
- Du menu contextuel, sélectionnez l'option Propriétés.
- De la barre d'outils, Cliquez sur le bouton .
L'image ci-dessus indique les propriétés du sous-formulaire incluant les cases Champs fils et Champs pères qui indiquent les champs en commun entre le sous-formulaire (fils) et le formulaire principal (père). On doit retrouver des champs en commun entre ces deux pour qu'une relation soit possible.
- Assurez-vous que le champ dans Champs fils est fact_id.
- Assurez-vous que le champ dans Champs pères est fact_id.
- Fermez la fenêtre des propriétés.