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

VBA Access Discussion :

case à cocher : empêcher une mise à jour


Sujet :

VBA Access

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Mars 2007
    Messages
    337
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 337
    Par défaut
    bonjour,

    je vous explique ma situation:

    j'ai un formulaire en mode feuille de données.
    l'un des champs est une case à cocher.

    je voudrais que, lorsque l'utilisateur coche cette case, que le code fasse des vérifications dans la base de données, pour savoir s'il a le droit ou non de cocher cette case. jusque là, tout va bien.(j'ai placé le code de vérif dans le afterUpdate).

    le souci qui se pose, c'est que lorsque le code détecte que l'utilisateur n'a pas le droit de cocher cette case, je ne sais pas trop comment faire réagir le code pour annuler la modif qu'il vient de faire:

    j'ai essayé de faire la modif en dur dans le code, façon bourrin, avec une requête update, qui remet la valeur de la case à cocher à 0, mais access me met un message:
    cet enregistrement a été modifié par un autre utilisateur depuis que vous avec commencé à modifier. si vous enregistrez ces modifications, vous écraserez celles effectuées par l'autre utilisateur............etc etc etc etc

    bon, access a raison de me rappeler à l'ordre, il est vrai que ma façon de faire est un peu bourrine.

    mais alors, comment faire ?!

    en fait, le but serait d'empêcher la mise à jour, mettre un code sur BeforeUpdate qui empêche justement l'update, mais est-ce possible ?

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour

    Pour gérer les droits, il y a cet excellent article.

  3. #3
    Membre confirmé Avatar de Orakle
    Homme Profil pro
    Responsable Informatique
    Inscrit en
    Mars 2004
    Messages
    204
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Responsable Informatique
    Secteur : Transports

    Informations forums :
    Inscription : Mars 2004
    Messages : 204
    Par défaut
    Salut,

    moi je verrais plus ça dans une gestion en amont niveau utilisateur, qui en fonction du user logué, activerait ou pas la dite case à cocher.
    Et là tu n'aurais plus de question à te poser.

  4. #4
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Orakle Voir le message
    Salut,

    moi je verrais plus ça dans une gestion en amont niveau utilisateur, qui en fonction du user logué, activerait ou pas la dite case à cocher.
    Et là tu n'aurais plus de question à te poser.
    c'est le lien que je viens de donner.

  5. #5
    Membre éclairé
    Inscrit en
    Mars 2007
    Messages
    337
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 337
    Par défaut
    en fait j'ai dû mal m'expliquer:
    ça n'est pas une question de droit d'utilisateur.
    en fait, ma case à cocher est liée à un champ dans une table, et suivant la valeur de l'enregistrement à laquelle elle est rattachée, on peut ou non la cocher. mais le fait de pouvoir ou non la cocher change à chaque enregistrement de ma table.
    donc ça n'est pas une question de droits, mais une question de données.

    j'espère que je suis plus claire comme ça....

  6. #6
    Membre expérimenté

    Profil pro
    Inscrit en
    Juin 2007
    Messages
    155
    Détails du profil
    Informations personnelles :
    Âge : 75
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 155
    Par défaut
    Bonjour,

    En fait, c'est l'événement BeforeUpDate que tu dois utiliser. Il comporte le paramètre Cancel qui doit être renseigné à True si l'on veut annuler la saisie. En un mot, ton code doit ressembler à :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Private Sub TaCaseACocher_BeforeUpDate(Cancel As Integer)
       If TaCaseACocher = True Then    
       ' 
       '  si on a coché la case  
       '
          If TaConditionPourInterdire = True Then
             MsgBox "Message pour dire que c'est interdit"
             Cancel = True
          End If
       End If
    Exit Sub
    Ainsi, l'utilisateur qui a coché la case alors qu'il ne devait pas le faire, verra le message, clickera sur Ok pour le faire disparaître, puis n'aura d'autre choix que taper la touche Esc pour s'en sortir.

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

Discussions similaires

  1. [MySQL] Associer un AND avec un CASE dans une mise à jour
    Par nicolas2603 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 19/08/2009, 11h20
  2. Problème d'une mise à jour
    Par Hamdi dans le forum Access
    Réponses: 2
    Dernier message: 17/09/2005, 13h57
  3. Case à cocher dans une requête
    Par kloss dans le forum Access
    Réponses: 6
    Dernier message: 14/10/2004, 11h44
  4. Comment empêcher la mise à jour d'un contrôle à l'écran ?
    Par JojoLaFripouille dans le forum Composants VCL
    Réponses: 4
    Dernier message: 19/09/2003, 12h52

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