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 :

BDD plante lors d'un parcours avec mise à jour d'un champ d'un recordset (sous formulaire) [AC-2013]


Sujet :

VBA Access

  1. #1
    Membre à l'essai
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Mai 2017
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Santé

    Informations forums :
    Inscription : Mai 2017
    Messages : 18
    Points : 14
    Points
    14
    Par défaut BDD plante lors d'un parcours avec mise à jour d'un champ d'un recordset (sous formulaire)
    Bonjour,


    Je rencontre des difficulté avec un le parcours et la mise à jour du recordset d'un sous formulaire LOL_DEMANAQ-SF dans le formulaire principal LOL_DEMANA.
    Lors du form_load, j'appelle un script NA_Click qui parcours le recordset rsDEMANAQ pour modifier rsDEMANAQ("on_vi") en fonction de rsDEMANAQ("on_na").

    A ce stade tout fonctionne bien.

    L'utilisateur peut ensuite modifier le rsDEMANAQ("on_na"), le script NA_Click est à nouveau exécuté mais à ce moment la base se plante.
    J'ai alors recopié le script dans un autre évènement rattaché au sous fourmulaire : Private Sub LIBELLE_DOMAINE_Click().
    Si l'utilisateur clique sur le libellé du domaine, le script se réexécute sans erreur.

    J'ai l'impression qu'il y a un conflit entre la modification d'une valeur d'un champs et du script contrôlant l'enregistrement concerné.
    J'ai d'ailleur le même problème si le champs modifié est différent du champs contrôlé...
    Auriez vous une piste ?


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    Option Compare Database
     
     
    Private Sub Form_Load()
     
    REQ_libelle = "SELECT libelle from lol_contexte where demande=0 ;" '
    Me.CONTEXTE.RowSource = REQ_libelle
    NA_Click
     
    End Sub
     
    Private Sub LIBELLE_DOMAINE_Click()
    Set rsDEMANAQ = Me.Form.Recordset
    Do Until rsDEMANAQ.EOF = True
        If rsDEMANAQ("on_na") = -1 Then
         rsDEMANAQ.Edit
       rsDEMANAQ("on_vi") = 0
         rsDEMANAQ.Update
        ElseIf rsDEMANAQ("on_na") = 0 Then
        rsDEMANAQ.Edit
        rsDEMANAQ("on_vi") = Null
        rsDEMANAQ.Update
        ElseIf IsNull(rsDEMANAQ("on_na")) Then
        rsDEMANAQ.Edit
        rsDEMANAQ("on_vi") = 2
        rsDEMANAQ.Update
        End If
    MsgBox (rsDEMANAQ.AbsolutePosition)
    MsgBox (rsDEMANAQ.RecordCount)
    rsDEMANAQ.MoveNext
    Loop
    End Sub
     
    Private Sub NA_Click()
        Set rsDEMANAQ = Me.Form.Recordset
    Do Until rsDEMANAQ.EOF = True
        If rsDEMANAQ("on_na") = -1 Then
         rsDEMANAQ.Edit
       rsDEMANAQ("on_vi") = 0
        rsDEMANAQ.Update
        ElseIf rsDEMANAQ("on_na") = 0 Then
        rsDEMANAQ.Edit
        rsDEMANAQ("on_vi") = Null
        rsDEMANAQ.Update
        ElseIf IsNull(rsDEMANAQ("on_na")) Then
        rsDEMANAQ.Edit
        rsDEMANAQ("on_vi") = 2
        rsDEMANAQ.Update
        End If
    MsgBox (rsDEMANAQ.AbsolutePosition)
    MsgBox (rsDEMANAQ.RecordCount)
    rsDEMANAQ.MoveNext
    Loop
    End Sub
     
    Private Sub SVG_AfterUpdate()
    If Me.SVG.Value = -1 Then
        Me.DATE_REVU_VB.Value = Now
        Me.PAR_VB.Value = gvLOGIN
    End If
    End Sub
    Merci d'avance

  2. #2
    Membre à l'essai
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Mai 2017
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Santé

    Informations forums :
    Inscription : Mai 2017
    Messages : 18
    Points : 14
    Points
    14
    Par défaut Bingo !
    Bonjour,

    Du coups, Me.recalc placé dans la fonction NA_Click avant de lancer la fonction et le tour est joué.

    A vrai dire je ne sais pas tout à fait pourquoi, si d'autres personnes ont plus d'info...

    PY

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 27/11/2016, 07h07
  2. Réponses: 1
    Dernier message: 03/03/2016, 10h56
  3. [AC-2003] Mise à jour de zone de liste déroulante dans sous formulaire
    Par fdalyon dans le forum IHM
    Réponses: 3
    Dernier message: 12/04/2010, 19h51
  4. Réponses: 2
    Dernier message: 15/07/2008, 09h00
  5. Mise à jour d'une table à partir d'un sous formulaire
    Par Daniel MOREAU dans le forum Access
    Réponses: 1
    Dernier message: 02/11/2005, 20h07

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