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 :

ne pas enregistrer dernier enregistrement


Sujet :

IHM

  1. #1
    Membre du Club
    Inscrit en
    Septembre 2008
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Septembre 2008
    Messages : 80
    Points : 48
    Points
    48
    Par défaut ne pas enregistrer dernier enregistrement
    Bonjour,

    J'ai un formulaire principal avec un bouton "QUITTER" et quelques sous-formulaires.
    Mes sous-formulaires servent à la fois de consultation de données, d'ajout ou de suppression de données. Ces sous-formulaires contiennent un bouton pour sauvegarder les données, un autre pour suppression (après choix dans une liste) puis un dernier pour annuler.
    Si je sélectionne ou que je saisis une donnée dans un sous-formulaire sans avoir cliquer sur le bouton "sauvegarder" puis que je quitte le sous-formulaire les données sont automatiquement enregistrées dans la table associée.
    Je me retrouve avec des enregistrements incomplet (avec des champs vides).
    Pour palier cela, dans un autre fichier, j'exécutais une requête suppression qui éliminait de la table tous les enregistrements incomplets.
    Sur le fichier actuel, dans les propriétés de tous les champs, j'ai mis Nul interdit = oui, comme ça, si tous les champs ne sont pas renseignés, j'ai un message d'erreur et l'utilisateur est obligé d'annuler.
    Cette solution bidouillage ne me convient pas.
    J'ai cherché sur le Net et essayé la méthode Me.undo ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DoCmd.DoMenuItem acFormBar, acEditMenu, acUndo, , acMenuVer70
    mais rien à faire, ça ne marche pas.
    J'ai essayé ces méthodes dans divers évènements des sous formulaires, sur le bouton "QUITTER" du formulaire principal mais sans résultat.
    Si quelqu'un a une solution, je le remercie d'avance.
    Bonne journée

  2. #2
    Rédacteur/Modérateur
    Avatar de Jeannot45
    Homme Profil pro
    Retraité
    Inscrit en
    Octobre 2004
    Messages
    3 871
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2004
    Messages : 3 871
    Points : 8 489
    Points
    8 489
    Par défaut


    Je pense que le fait d'aller cliquer sur le bouton "Annuler", fait quitter le focus de l'enregistrement en cours et provoque donc l'enregistrement de celui-ci. Il te faudra donc procéder par l'exécution d'une requete suppression qui n'agira que sur le dernier enregistrement saisi.

    bonne continuation

  3. #3
    Membre du Club
    Inscrit en
    Septembre 2008
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Septembre 2008
    Messages : 80
    Points : 48
    Points
    48
    Par défaut
    Salut,

    Merci pour ta réponse.
    Quand je clique sur "Annuler" dans un sous-formulaire, il n'y a pas de problème, tous mes contrôles sont vidés et l'enregistrement est annulé.
    C'est quand je clique sur "QUITTER" du formulaire principal et qu'un contrôle d'un sous-formulaire est rempli.
    J'aurais souhaité que si on quitte le formulaire principal et que des contrôles sont remplis dans les sous-formulaires, l'enregistrement ne se fasse pas.
    J'ai essayé d'atteindre les sous-formulaires depuis le bouton "QUITTER" du formulaire principal de la manière suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
        Me.Undo
        Form_grp.Undo
        Form_Stg.Undo
        DoCmd.DoMenuItem acFormBar, acEditMenu, acUndo, , acMenuVer70
        DoCmd.Close
    un espèce de mixte de tout ce que j'ai pu trouver sur le Net, mais rien à faire ; ça ne marche pas.

    Suis-je vraiment obligé de passer par des requêtes suppression ou la propriété Nul interdit ?

  4. #4
    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
    Par défaut
    Lorsque vous quittez votre sous formulaire, la transaction est validée par le rafraichissement du sous formulaire.
    Le bouton Annuler fonctionne donc bien mais il fonctionne uniquement dans la transaction du formulaire qui le contient.

    Les seules solutions :

    - Procéder à une suppression, avec les risques que cela suppose dans un environnement multi-utilisateur
    - Procéder à un "tagguage" de l'enregistrement, celui ci ne devient validé que lorsque son champ "EnCoursModif" est à Faux. Dans ce cas, il faut faire en sorte que les utilisateurs ne voient pas un tel enregistrement
    - Utiliser des formulaires basés sur des tables temporaires et gérer vous même les transactions

  5. #5
    Membre du Club
    Inscrit en
    Septembre 2008
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Septembre 2008
    Messages : 80
    Points : 48
    Points
    48
    Par défaut Re
    Merci pour ta réponse,

    Ta réponse est claire et net. Il n'y a rien à rajouter si ce n'est... merci.
    Bonne journée.

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

Discussions similaires

  1. Jointure qui ne renvoie pas tous les enregistrements
    Par rayonx dans le forum Langage SQL
    Réponses: 12
    Dernier message: 19/07/2024, 09h33
  2. [MySQL-5.0] GROUP BY qui ne donne pas les derniers enregistrements
    Par laul33 dans le forum Requêtes
    Réponses: 5
    Dernier message: 08/03/2014, 15h05
  3. [Toutes versions] Savoir si on se trouve ou pas sur le dernier enregistrement d'un formulaire
    Par Mat08 dans le forum VBA Access
    Réponses: 5
    Dernier message: 23/01/2010, 13h21
  4. Réponses: 3
    Dernier message: 19/09/2007, 13h09
  5. Trouver le dernier enregistrement d'une table
    Par remi59 dans le forum Requêtes
    Réponses: 4
    Dernier message: 11/03/2003, 14h54

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