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

VB 6 et antérieur Discussion :

Lenteur de traitement


Sujet :

VB 6 et antérieur

  1. #1
    Candidat au Club
    Inscrit en
    Octobre 2007
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 4
    Points : 4
    Points
    4
    Par défaut Lenteur de traitement
    Bonjour à tous!
    J'ai lu cette discussion.
    J'ai le même problème de temps lorsque je veux transférer des données vers une base. Je n'arrive pas à utiliser begintrans et commitrans.
    En fait, je les ai utilisés dans le code. Ça s'exécute normalement mais je ne vois pas d'amélioration en ce qui concerne le temps.
    voici mon code:


    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
        Fice = fichier
        Open Fice For Input As #1
        ' Ouverture de la table
        Set rc = dbase.OpenRecordset("client1") ', dbaseopentable) 
        td = 0
     
        Do While Not EOF(1)
            Line Input #1, LignE
            TableW() = Split(LignE, "|")
            rc.AddNew
     
            On Error Resume Next
     
            dbase.Execute " BeginTrans " 
            For i = 0 To UBound(TableW)
                rc.Fields(i).Value = TableW(i) ' Création d'une ligne
                td = i + 1
                If td Mod 200 = 0 Then
                    dbase.Execute " CommiTrans"
                End If 
            Next i
     
            rc.Update
     
        Loop
     
        MsgBox (" remplissage de la table terminée!"), vbExclamation, "Fin de l'importation"
     
        Close #1
        rc.Close
        Set rc = Nothing
        dbase.Close
     
    End Sub

  2. #2
    Membre expert
    Avatar de Delbeke
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    2 675
    Détails du profil
    Informations personnelles :
    Âge : 70
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 2 675
    Points : 3 696
    Points
    3 696
    Par défaut
    Inutile de t'énerver

    Pourquoi tu fais un comittrans en plein milieu , et pas à la fin ?

    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
    dbase.Execute " BeginTrans " 
     
    Do While Not EOF(1)
      Line Input #1, LignE
      TableW() = Split(LignE, "|")
      rc.AddNew
     
      On Error Resume Next
      For i = 0 To UBound(TableW)
         rc.Fields(i).Value = TableW(i) ' Création d'une ligne
      Next i
     
      rc.Update
     
    Loop
    dbase.Execute " CommiTrans"
    En général, on ne demande de conseils que pour ne pas les suivre ou, si on les a suivis, reprocher à quelqu'un de les avoir donnés
    (ALEXANDRE DUMAS)

    N'hésitez pas à visiter ma page de contributions

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 10
    Points : 11
    Points
    11
    Par défaut
    Effectivement, les performances et la sécurité des transactions a un intérêt que si on effectue :
    - un BeginTrans au début d'une suite d'opérations
    - un CommiTrans à la fin du groupe d'opérations qui doit réussir ou foirer.

    C'est le concept même de la transaction (et limiter les problèmes quand une suite de requêtes foire en plein milieu et qu'on aurait dû s'y attendre...)

  4. #4
    Candidat au Club
    Inscrit en
    Octobre 2007
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 4
    Points : 4
    Points
    4
    Par défaut
    MERCI, pour la contribution.
    je vais tester et si ca marche mieux je viendrai mettre le code ici pour aider ceux qui auront le même pb que moi.
    merci et bne jnée!

  5. #5
    Expert confirmé
    Avatar de zazaraignée
    Profil pro
    Étudiant
    Inscrit en
    Février 2004
    Messages
    3 174
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2004
    Messages : 3 174
    Points : 4 085
    Points
    4 085
    Par défaut
    Pour avoir ajouté les indentations dans ton code (ce qui le rends plus lisible), j'ai remarqué quelques anomalies et/ou imprudences...

    1. Ne jamais prendre pour acquis que le numéro de fichier #1 est disponible. Donc à la place de ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Open Fice For Input As #1
    il vaut mieux utiliser la fonction FreeFile comme cela:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Dim numFichier As Integer
    [...]
    numFichier = FreeFile
    OpenFice For Input As #numFichier
    [...]
    Do While Not EOF(numFichier)
      Line Input #numfichier, LignE
    2. Je crois bien que la seconde parenthèse de ton MsgBox est au mauvais endroit... Et de toutes façons, si tu n'as pas l'intention de vérifier la valeur du bouton cliqué, il n'est pas nécessaire de mettre les parenthèses. Il se peut que VB s'en plaigne lors de l'exécution... Donc, à la place de ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MsgBox (" remplissage de la table terminée!"), vbExclamation, "Fin de l'importation"
    procéder comme cela:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Dim reponse As Integer
    [...]
    reponse = MsgBox("Remplissage de la table terminé!" & vbCrLf & _
                     "Voulez-vous compléter la transaction?"), _
                     vbExclamation + vbYesNo, "Fin de l'importation")
    If reponse = vbYes Then
        ' commit
      Else
        ' cancel
    End If
    ou tout simplement comme ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MsgBox "Remplissage de la table terminé!"

Discussions similaires

  1. [Batch] Fichier avec grand nombre de lignes et lenteur de traitement
    Par Aguire_ dans le forum Scripts/Batch
    Réponses: 2
    Dernier message: 09/05/2015, 09h10
  2. [XL-2010] Lenteur de traitement inattendue
    Par GSFBC dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 29/07/2014, 09h41
  3. Lenteur de traitement checkbox avec IE
    Par maestro982 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 15/10/2010, 10h06
  4. [Débutant] Lenteur de traitement après utilisation de gui
    Par MrPingouin dans le forum Interfaces Graphiques
    Réponses: 18
    Dernier message: 19/06/2009, 17h44
  5. [WD11]Lenteur de traitement fichier XLS
    Par arnaud_verlaine dans le forum WinDev
    Réponses: 2
    Dernier message: 10/09/2007, 15h27

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