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 :

Lenteur éxécution VBA


Sujet :

VBA Access

  1. #1
    Membre régulier Avatar de Arola78
    Homme Profil pro
    Retraité
    Inscrit en
    Avril 2003
    Messages
    133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Avril 2003
    Messages : 133
    Points : 94
    Points
    94
    Par défaut Lenteur éxécution VBA
    Bonsoir,
    A l'ouverture d'un formulaire j'éxécute ceci :
    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
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    Private Sub BoutonSuite_Click()
    '=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
    ' Auteur Claude Perelli Créé le 6 juin 2008
    '=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
    ' Objet         Effectuer les mises à jour automatiques et les initialisations
    '
    ' Description   - initialisation de la Log
    '               - recencement des différentes Nature de titres
    '               - calculs des pondérations liées aux multiples
    '               - ré-évaluation annuelle de la valeur des titres
    '               - mise à jour de l'occupation des classeurs
    '               - suppression des lignes Objets dans Paramètres
    '               - recensement des Etats
    '               - recensement des Ecrans/Formulaires
    '               - recensement des Macros
    '               - recensement des Requêtes
    '               - recensement des Tables
    '               - recensement des Modules
    '
    ' Remarques     Lorsque l'on travaille sur la base de Références, les formulaires sont automatiquement mis en Plein écran
    '               façon PowerPoint alors que cela se fait par le bouton dans les autres bases.
    '
    '=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
    ' Modifié(e) le
    '=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
        On Error GoTo Err_BoutonSuite_Click
     
    '-----------------------------------------------------------
    '   Déclaration des variables et initialisations
    '-----------------------------------------------------------
        Dim SQL             As String
        Dim SQLup           As String
        Dim dbCurrent       As Database
        Dim stEcran         As String
        Dim stClauseWhere   As String
        Dim Curseur         As DAO.Recordset
        Dim Titre_évalué    As String
        Dim Nb              As Integer
        Dim Comments        As String
        Dim stIndex         As String
        Dim stTitre         As String
        Dim stVal           As Double
        Dim stClassement    As String
        Dim stValeurs       As String
        Dim stCritere       As String
        Dim stNbr           As String
     
        Set dbCurrent = CurrentDb()
        DoCmd.SetWarnings True
     
    '-----------------------------------------------------------       testée ok
    '   Initialisation de la Log
    '-----------------------------------------------------------
    ' Suppression de la ligne 'Début de session' dans la Log
    ' DoCmd.OpenQuery "1R-LOG-DELETE-SESSION", acViewNormal, acEdit
        SQL = "DELETE FROM Log WHERE Jour = date() AND Action = 'Début' ;"
        DoCmd.RunSQL (SQL)
     
    ' Inscription d'une nouvelle ligne 'Début de session' dans la Log
    ' DoCmd.OpenQuery "1R-LOG-INSERT-DEBUT SESSION", acViewNormal, acEdit
        SQL = "INSERT INTO Log ( num, Jour, Heure, auteur, [Action], Compteur, Libellé, Impact, Type ) "
        SQL = SQL & "VALUES (time()*1, Date(), 0, '1E-Ecran Présentation', 'Début', 0, "
        SQL = SQL & "'------------------------------------------------------------ Début de session -------------------------------------------------------------- ', 'Log', 'LOG') ;"
        DoCmd.RunSQL (SQL)
        MsgBox "Log"
    '------------------------------------------------                    testée ok
    ' Recencement des différentes Nature de titres
    '------------------------------------------------
    ' DoCmd.RunMacro "1M-NATURE des TITRES", , ""
    ' Suppression des lignes HISTORIQUE NAT-TITRE dans la table PARAMETRES
    ' DoCmd.OpenQuery "1R-PARAM-NATURE-TITRE-DELETE", acViewNormal, acEdit
        SQL = "DELETE * FROM Paramètres WHERE Article = 'NAT-TITRE' ;"
        DoCmd.RunSQL (SQL)
     
    ' Update des lignes NAT-TITRE en HISTORIQUE  NAT-TITRE
    ' DoCmd.OpenQuery "1R-PARAM-NATURE-TITRE-UPDATE", acViewNormal, acEdit        <<<--- supprimé
     
    ' Insertion des lignes NAT-TITRE dans la table PARAMETRES
    ' DoCmd.OpenQuery "1R-PARAM-NATURE-TITRE-INSERT", acViewNormal, acEdit
        SQL = "INSERT INTO Paramètres ( Article, lib1, lib2, lib3, libc1, libc2, libc3, libl1, libl2, libl3, cpt1, cpt2, cpt3, num1, num2, num3, pct1, pct2, pct3, date1, date2, date3, maj ) "
        SQL = SQL & "SELECT 'NAT-TITRE', ' ', ' ', ' ', ' ', ' ', ' ', [Titre], ' ', ' ', Count(*), 0, 0, 0, 0, 0, 0, 0, 0, date(), date(), date(), date() "
        SQL = SQL & "FROM Valeurs GROUP BY [Titre] ;"
        DoCmd.RunSQL (SQL)
        MsgBox "Nature de titre"
    '------------------------------------------------                   testée ok
    ' Calculs des pondérations liées aux multiples
    '------------------------------------------------
    ' DoCmd.RunMacro "1M-MULTIPLE", , ""
     
    ' RAZ des colonnes MULTIPLES et COEFFICIENT dans la table VALEURS
    ' DoCmd.OpenQuery "1R-VALEURS-MULTI+COEFF-UPDATE", acViewNormal, acEdit
        SQL = "UPDATE Valeurs SET Multiple = 0, Coefficient = 0 ;"
        DoCmd.RunSQL (SQL)
     
    ' Mise à jour de la colonne MULTIPLES dans la table VALEURS
    '    DoCmd.OpenQuery "1R-VALEURS-MULTIPLES-UPDATE", acViewNormal, acEdit
     
    ' Ouverture d'un curseur pour recenser les multi-valeurs
        SQL = "SELECT Index as Indx, COUNT(*) as Nbr FROM Valeurs GROUP BY Index ;"
        Set Curseur = CurrentDb.OpenRecordset(SQL)
     
    ' Lecture du curseur et MAJ de Multiple pour les multi-valeurs
        While Not Curseur.EOF
            Nb = Curseur.Fields("Nbr").Value
            stIndex = Curseur.Fields("Indx").Value
            SQLup = "UPDATE Valeurs SET Multiple = " & "'" & Nb & "'  WHERE Index = " & "'" & stIndex & "'    ;"
            DoCmd.RunSQL (SQLup)
            Curseur.MoveNext
        Wend
     
    ' Mise à jour de la colonne COEFFICIENT dans la table VALEURS
    ' DoCmd.OpenQuery "1R-VALEURS-COEFFICIENT-UPDATE", acViewNormal, acEdit
        SQL = "UPDATE Valeurs AS A INNER JOIN Paramètres AS B ON A.Multiple=B.Cpt3 SET A.Coefficient = B.Num1 ;"
        DoCmd.RunSQL (SQL)
        MsgBox "Multiple"
    '-----------------------------------------------------              testée ok
    ' Ré-évaluation annuelle de l'estimation des titres
    '-----------------------------------------------------
    ' DoCmd.OpenQuery "1R-PARAM-ESTIMATION-INSERT", acViewNormal, acEdit
    ' DoCmd.RunMacro "1M-RE-EVALUATION", , ""
     
    ' Ouverture d'un curseur pour les titres à ré-évaluer
        SQL = "SELECT ucase(Index) as Indx, Titre, (Estimation + (Estimation * 3/100)) as NewVal  FROM Valeurs WHERE (date() - DateEstimation) > 365 ORDER BY 1;"
        Set Curseur = CurrentDb.OpenRecordset(SQL)
     
    ' Lecture du curseur et insertion d'une ligne dans la Log
        Nb = 0
        While Not Curseur.EOF
            Comments = Curseur.Fields("Indx").Value & " " & Curseur.Fields("Titre").Value & " estimé(e) à " & Format(Curseur.Fields("NewVal").Value, "# ##0.,00") & " €"
            SQLup = "INSERT INTO Log ( Num, Jour, Heure, Auteur, [Action], Compteur, Libellé, Impact, Type ) "
            SQLup = SQLup & "VALUES (time()*1, Date(), time(), '1E-Ecran Présentation', 'Ré-évaluation', 1, "
            SQLup = SQLup & "'" & Comments & "', 'Valeurs', 'LOG');"
            DoCmd.RunSQL (SQLup)
            Curseur.MoveNext
            Nb = Nb + 1
            MsgBox Comments
        Wend
     
    ' Ré-évaluation
    ' DoCmd.OpenQuery "1R-VALEURS-ESTIMATION-UPDATE", acViewNormal, acEdit
        SQL = "UPDATE Valeurs SET DateEstimation = ([DateEstimation] + 365), Estimation = ([Estimation] + ([Estimation] * 3/100)) WHERE (date()-DateEstimation) > 365 ;"
        DoCmd.RunSQL (SQL)
     
        If Nb > 0 Then
            MsgBox "Nombre de titre(s) ré-évalué(s) :     " & Nb & vbCrLf & "Voir la liste dans la Log.", vbInformation, "ScripoGest - Evaluation"
        End If
        MsgBox "Esimation"
    '-----------------------------------------------------                                                  testée ok
    ' Mise à jour de l'occupation des classeurs
    '-----------------------------------------------------
    ' DoCmd.RunMacro "1M-RANGEMENT", , ""
     
    ' 1/ Comptage du nombre de titres par classeurs
    ' ---------------------------------------------
    '    DoCmd.OpenQuery "1R-PARAM-CLASSEUR-COMPTAGE", acViewNormal, acEdit
    ' Ouverture d'un curseur pour compter le nombre de titres par classeurs
        SQL = "SELECT Classement, COUNT(*) as Nbr FROM Valeurs GROUP BY Classement ;"
        Set Curseur = CurrentDb.OpenRecordset(SQL)
     
    ' Lecture du curseur et MAJ des nombres de titres par classeur dans Paramètres
        While Not Curseur.EOF
            Nb = Curseur.Fields("Nbr").Value
            stClassement = Curseur.Fields("Classement").Value
            SQLup = "UPDATE Paramètres SET Cpt2 = " & "'" & Nb & "' "
            SQLup = SQLup & " WHERE Article = 'CLASSEUR' AND Lib1 = " & "'" & stClassement & "'    ;"
            DoCmd.RunSQL (SQLup)
            Curseur.MoveNext
        Wend
     
    ' 2/ Calcul du taux d'occupation
    ' ------------------------------
    '   DoCmd.OpenQuery "1R-PARAM-CLASSEUR-TAUX", acViewNormal, acEdit
     
        SQL = "UPDATE Paramètres SET Cpt3 = ((Cpt2*100)/Cpt1) WHERE Cpt1 > 0 ;"
        DoCmd.RunSQL (SQL)
     
    ' 3/ Interprétation du taux d'occupation
    ' --------------------------------------
    '    DoCmd.OpenQuery "1R-PARAM-CLASSEUR-FULL", acViewNormal, acEdit
     
        SQL = "UPDATE Paramètres SET Lib3 = 'Plein' WHERE Article = 'Classeur' And Cpt3 > 99 ;"
        DoCmd.RunSQL (SQL)
     
    ' 4/ Interprétation du taux d'occupation - suite
    ' ----------------------------------------------
    '    DoCmd.OpenQuery "1R-PARAM-CLASSEUR-OCCUPATION", acViewNormal, acEdit
     
        SQL = "UPDATE Paramètres SET Lib3 = (Cpt3) WHERE Article = 'Classeur' And Cpt3 Between 0 And 99 And Lib1 <> 'hors' ;"
        DoCmd.RunSQL (SQL)
        MsgBox "Rangement"
    '------------------------------------------------                               testée ok
    ' Suppression des lignes Objets dans Paramètres
    '------------------------------------------------
    '    DoCmd.OpenQuery "1R-PARAM-SYS-DELETE-OBJETS", acViewNormal, acEdit
     
        SQL = "DELETE FROM Paramètres WHERE (Left$([Article],3) = 'SYS'); "
        DoCmd.RunSQL (SQL)
        MsgBox "Objets"
    '------------------------------------------------                               testée ok
    ' Recensement des Etats
    '------------------------------------------------
    '    DoCmd.OpenQuery "1R-PARAM-SYS-INSERT-ETATS", acViewNormal, acEdit
     
        SQL = "INSERT INTO Paramètres ( Article, lib1, lib2, lib3, libc1, libc2, libc3, libl1, libl2, libl3, cpt1, cpt2, cpt3, num1, num2, num3, pct1, pct2, pct3, date1, date2, date3, maj ) "
        SQL = SQL & "SELECT 'SYSETAT', 'Etat', ' ', ' ', ' ', ' ', ' ', MSysObjects.Name, ' ', ' ', 0, 0, 0, 0, 0, 0, 0, 0, 0, date(), date(), date(), date() "
        SQL = SQL & "FROM MSysObjects WHERE (Left$([Name], 1) <> '~') And (MSysObjects.Type) = -32764 ORDER BY MSysObjects.Name ;"
        DoCmd.RunSQL (SQL)
        MsgBox "Etats"
    '------------------------------------------------                               testée ok
    ' Recensement des Ecrans/Formulaires
    '------------------------------------------------
    '    DoCmd.OpenQuery "1R-PARAM-SYS-INSERT-ECRAN", acViewNormal, acEdit
     
        SQL = "INSERT INTO Paramètres ( Article, lib1, lib2, lib3, libc1, libc2, libc3, libl1, libl2, libl3, cpt1, cpt2, cpt3, num1, num2, num3, pct1, pct2, pct3, date1, date2, date3, maj ) "
        SQL = SQL & "SELECT 'SYSECRAN', 'Ecran/Form', ' ', ' ', ' ', ' ', ' ', MSysObjects.Name, ' ', ' ', 0, 0, 0, 0, 0, 0, 0, 0, 0, date(), date(), date(), date() "
        SQL = SQL & "FROM MSysObjects WHERE (Left$([Name], 1) <> '~') And (MSysObjects.Type) = -32768 And ([Name] Like '1E-*' Or [Name] Like '1F-*') ORDER BY MSysObjects.Name ;"
        DoCmd.RunSQL (SQL)
        MsgBox "Ecrans"
    '------------------------------------------------                           testée ok
    ' Recensement des Macros
    '------------------------------------------------
    '    DoCmd.OpenQuery "1R-PARAM-SYS-INSERT-PROC", acViewNormal, acEdit
     
        SQL = "INSERT INTO Paramètres ( Article, lib1, lib2, lib3, libc1, libc2, libc3, libl1, libl2, libl3, cpt1, cpt2, cpt3, num1, num2, num3, pct1, pct2, pct3, date1, date2, date3, maj ) "
        SQL = SQL & "SELECT 'SYSMACRO', 'Macro', ' ', ' ', ' ', ' ', ' ', MSysObjects.Name, ' ', ' ', 0, 0, 0, 0, 0, 0, 0, 0, 0, date(), date(), date(), date() "
        SQL = SQL & "FROM MSysObjects WHERE (Left$([Name], 1) <> '~') And (MSysObjects.Type) = -32766 And ((Left$([Name],3) = '1M-') Or [Name]='autoexec') ORDER BY MSysObjects.Name ;"
        DoCmd.RunSQL (SQL)
        MsgBox "Macros"
    '------------------------------------------------                           testée ok
    ' Recensement des Requêtes
    '------------------------------------------------
    '    DoCmd.OpenQuery "1R-PARAM-SYS-INSERT-QUERY", acViewNormal, acEdit
     
        SQL = "INSERT INTO Paramètres ( Article, lib1, lib2, lib3, libc1, libc2, libc3, libl1, libl2, libl3, cpt1, cpt2, cpt3, num1, num2, num3, pct1, pct2, pct3, date1, date2, date3, maj ) "
        SQL = SQL & "SELECT 'SYSQUERY', 'Requête', ' ', ' ', ' ', ' ', ' ', MSysObjects.Name, ' ', ' ', 0, 0, 0, 0, 0, 0, 0, 0, 0, date(), date(), date(), date() "
        SQL = SQL & "FROM MSysObjects WHERE (Left$([Name], 1) <> '~') And (MSysObjects.Type) = 5 And ([Name] Like '1R-*') ORDER BY MSysObjects.Name ;"
        DoCmd.RunSQL (SQL)
        MsgBox "Requêtes"
    '------------------------------------------------                       testée ok
    ' Recensement des Tables
    '------------------------------------------------
    '    DoCmd.OpenQuery "1R-PARAM-SYS-INSERT-TABLE", acViewNormal, acEdit
     
        SQL = "INSERT INTO Paramètres ( Article, lib1, lib2, lib3, libc1, libc2, libc3, libl1, libl2, libl3, cpt1, cpt2, cpt3, num1, num2, num3, pct1, pct2, pct3, date1, date2, date3, maj ) "
        SQL = SQL & "SELECT 'SYSTABLE', 'Table', ' ', ' ', ' ', ' ', ' ', MSysObjects.Name, ' ', ' ', 0, 0, 0, 0, 0, 0, 0, 0, 0, date(), date(), date(), date() "
        SQL = SQL & "FROM MSysObjects WHERE (Left$([Name], 1) <> '~') And (Left$([Name], 4) <> 'Msys') And (MSysObjects.Type) = 1 ORDER BY MSysObjects.Name ;"
        DoCmd.RunSQL (SQL)
        MsgBox "Tables"
    '------------------------------------------------                  testée ok
    ' Recensement des Modules
    '------------------------------------------------
    '    DoCmd.OpenQuery "1R-PARAM-SYS-INSERT-MODULE", acViewNormal, acEdit
     
        SQL = "INSERT INTO Paramètres ( Article, lib1, lib2, lib3, libc1, libc2, libc3, libl1, libl2, libl3, cpt1, cpt2, cpt3, num1, num2, num3, pct1, pct2, pct3, date1, date2, date3, maj ) "
        SQL = SQL & "SELECT 'SYSMODULE', 'Module', ' ', ' ', ' ', ' ', ' ', MSysObjects.Name, ' ', ' ', 0, 0, 0, 0, 0, 0, 0, 0, 0, date(), date(), date(), date() "
        SQL = SQL & "FROM MSysObjects WHERE (Left$([Name], 1) <> '~') And (MSysObjects.Type) = -32761 And (Left$([Name], 3) = '1M-') ORDER BY MSysObjects.Name ;"
        DoCmd.RunSQL (SQL)
        MsgBox "Modules"
    ' Rétablissement des messages
        DoCmd.SetWarnings True
     
    ' DoCmd.RunMacro "1M-MAJ AUTOMATIQUES"
     
        stEcran = "1E-Ecran Général"
        DoCmd.OpenForm stEcran, , , stClauseWhere
     
    Exit_BoutonSuite_Click:
        Exit Sub
     
    Err_BoutonSuite_Click:
        MsgBox err.Description
        Resume Exit_BoutonSuite_Click
     
    End Sub
    Le code s'éxécute lentement et au bout d'un moment Access ne répond plus.
    C'est la partie Rangement qui semble très lente
    Quelqu'un a-t-il une explication ou a-t-il déjà rencontré ce problème.
    PS j'ai désinstallé puis réinstallé Access, mais cela n'a rien fait
    Merci

  2. #2
    Membre habitué
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Mai 2008
    Messages
    382
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2008
    Messages : 382
    Points : 191
    Points
    191
    Par défaut
    Bonjour,

    Je pense qu'il faut supprimer le maximum de requete. Il faut optimiser en faisant des jointures de tables.
    Si ton code se répète, au lieu de mettre toutes les requetes, fait plutot une boucle.

  3. #3
    Membre régulier Avatar de Arola78
    Homme Profil pro
    Retraité
    Inscrit en
    Avril 2003
    Messages
    133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Avril 2003
    Messages : 133
    Points : 94
    Points
    94
    Par défaut
    Bonjour et merci de m'avoir répondu.
    Quant aux requêtes, évidemment cela irait beaucoup plus vite s'il n'y en avait pas ! Mais elles y sont et me sont fort utiles.
    Plus sérieusement, est-ce que les commentaires influent sur le temps d'éxécution et comment se fait-il qu'au bout d'un moment Access ne réponde plus ?
    Merci

  4. #4
    Rédacteur/Modérateur

    Avatar de ClaudeLELOUP
    Homme Profil pro
    Chercheur de loisirs (ayant trouvé tous les jours !)
    Inscrit en
    Novembre 2006
    Messages
    20 596
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 79
    Localisation : Belgique

    Informations professionnelles :
    Activité : Chercheur de loisirs (ayant trouvé tous les jours !)
    Secteur : Finance

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 596
    Points : 281 920
    Points
    281 920
    Par défaut
    Bonjour Arola,

    Impressionnant !

    Le code s'éxécute lentement et au bout d'un moment Access ne répond plus
    Je t'avoue que j'ai essayé de lire le code ... mais au bout d'un moment, j'étais comme ton Access : sans voix !

    Ne peux-tu organiser ton formulaire pour que seules le actions utiles se déclenchent au moment où tu détectes qu'elles sont nécessaires à l'utilisateur ?
    Pour l'instant, tu fais un tas de choses a priori et cela demande du temps.
    Si tu les faisais au fur et à mesure que le besoin s'en manifeste, le délai d'attente deviendrait imperceptible pour l'utilisateur.

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

    De plus, cela dépend du nombre d'enregistrements que tu traites (1000 ou 1 000 000), cela n'est pas la même chose.

    Starec

  6. #6
    Membre régulier Avatar de Arola78
    Homme Profil pro
    Retraité
    Inscrit en
    Avril 2003
    Messages
    133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Avril 2003
    Messages : 133
    Points : 94
    Points
    94
    Par défaut
    Bonsoir et merci de vous être penché sur mon problème,
    Je n'ai que 400 enregistrements environ dans ma table principale et 3.000 dans une autre, je ne pense pas que cela vienne de là. De plus j'ai l'occasion d'éxécuter ce code sur un poste tournant sous XP et ça se passe très bien (y a-t-il un lien ???).
    Ce qui me trouble vraiment c'est qu'au bout d'un moment Access ne réponde plus. Il semblerait que se soit le code suivant qui provoque cette perte d'Access
    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
    '-----------------------------------------------------                                                  
    ' Mise à jour de l'occupation des classeurs
    '-----------------------------------------------------
     
    ' 1/ Comptage du nombre de titres par classeurs
    ' ---------------------------------------------
    ' Ouverture d'un curseur pour compter le nombre de titres par classeurs
        SQL = "SELECT Classement, COUNT(*) as Nbr FROM Valeurs GROUP BY Classement ;"
        Set Curseur = CurrentDb.OpenRecordset(SQL)
     
    ' Lecture du curseur et MAJ des nombres de titres par classeur dans Paramètres
        While Not Curseur.EOF
            Nb = Curseur.Fields("Nbr").Value
            stClassement = Curseur.Fields("Classement").Value
            SQLup = "UPDATE Paramètres SET Cpt2 = " & "'" & Nb & "' "
            SQLup = SQLup & " WHERE Article = 'CLASSEUR' AND Lib1 = " & "'" & stClassement & "'    ;"
            DoCmd.RunSQL (SQLup)
            Curseur.MoveNext
        Wend
     
    ' 2/ Calcul du taux d'occupation
    ' ------------------------------
     
        SQL = "UPDATE Paramètres SET Cpt3 = ((Cpt2*100)/Cpt1) WHERE Cpt1 > 0 ;"
        DoCmd.RunSQL (SQL)
     
    ' 3/ Interprétation du taux d'occupation
    ' --------------------------------------
     
        SQL = "UPDATE Paramètres SET Lib3 = 'Plein' WHERE Article = 'Classeur' And Cpt3 > 99 ;"
        DoCmd.RunSQL (SQL)
     
    ' 4/ Interprétation du taux d'occupation - suite
    ' ----------------------------------------------
     
        SQL = "UPDATE Paramètres SET Lib3 = (Cpt3) WHERE Article = 'Classeur' And Cpt3 Between 0 And 99 And Lib1 <> 'hors' ;"
        DoCmd.RunSQL (SQL)
    Qu'en pensez-vous ?

    J'ai oublié, lorsque Access part en vrille il me crée un fichier qui porte le même nom que ma base mais avec une extension .ldb, voilà.

  7. #7
    Membre régulier Avatar de Arola78
    Homme Profil pro
    Retraité
    Inscrit en
    Avril 2003
    Messages
    133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Avril 2003
    Messages : 133
    Points : 94
    Points
    94
    Par défaut
    Bonjour,
    Je n'ai toujours pas trouvé d'explication au problème que je vous ai soumis mais j'ai rétablis une situation "normale". Avant de mettre en place ce code j'avais passé un utilitaire de nettoyage CCleaner qui a rafraichit la Base de registre. J'ai restauré cette Base de registre avant nettoyage et depuis l'éxécution du code est un peu plus rapide, et surtout il va jusqu'au bout sans se planter.
    Voilà, si quelqu'un a un jour un problème similaire ....
    Bonne journée à tous.

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 05/06/2006, 12h59
  2. [VBA-E] Lenteur de chargement d'un fichier
    Par Amoust dans le forum Macros et VBA Excel
    Réponses: 31
    Dernier message: 01/06/2006, 10h08
  3. Réponses: 10
    Dernier message: 09/05/2006, 22h37
  4. [VBA-E]Problème d'éxécution de macros à l'ouverture d'éxcel
    Par mulot03 dans le forum Macros et VBA Excel
    Réponses: 12
    Dernier message: 26/04/2006, 19h02
  5. [VBA EXCEL] Problème d'éxécution avec graphiques
    Par RedBurn dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 28/11/2005, 10h55

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