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

Access Discussion :

[Access2003/VBA]Import de table volumineuse


Sujet :

Access

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    481
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 481
    Points : 165
    Points
    165
    Par défaut [Access2003/VBA]Import de table volumineuse
    Bonjour à tous,

    Mon problème aujourd'hui est de réaliser l'import d'une table de très grand taille.

    J'ai fais quelquechose qui marche très bien lorsque la table est de petite taille mais là quand il s'agit de traiter une table de plus de 8000 enregistrements apapremment ça ne marche plus.

    Est ce que quelqu'un aurait une idée ?

    Voici une partie de la procédure qui fait ça :

    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
     
     
    
    Private Sub cmdRegion_Click()
        
        Dim db          As DAO.Database
        Dim recEnreg    As DAO.Recordset
        Dim sSQL        As String
        
        Me.ProgressBar1.Value = 0
        
        sSQL = "SELECT dbo_OSMOSE_SITE_THEORIQUE.REGION_EXPLOITATION as LaRegion"
        sSQL = sSQL & " FROM dbo_OSMOSE_SITE_THEORIQUE"
        sSQL = sSQL & " Union"
        sSQL = sSQL & " Select " & """" & "NAT" & """" & " From dbo_OSMOSE_SITE_THEORIQUE AS LaRegion"
        
        Set db = DBEngine.Workspaces(0).Databases(0)
        Set recEnreg = db.OpenRecordset(sSQL, dbOpenSnapshot)
        
        On Error Resume Next
        
        If StrTable = "Regions" Then
            sSQL = "insert into Region values ('IDF-RN')"
            Call db.Execute(sSQL)
            While Not recEnreg.EOF
                If (recEnreg!LaRegion <> "IDF" And recEnreg!LaRegion <> "RN") Then
                    sSQL = "insert into Region values ('" & recEnreg!LaRegion & "')"
                    Call db.Execute(sSQL)
                End If
                Call recEnreg.MoveNext
                Me.ProgressBar1.Value = recEnreg.PercentPosition
                Me.LblPercent.Caption = Format(recEnreg.PercentPosition / 100, "0.00 %")
            Wend
            Me.Repaint
    
    '=> La partie qui m'intéresse se situe ici :    
        ElseIf StrTable = "Villes" Then
            Set recEnreg = db.OpenRecordset("reqAlimVille", dbOpenSnapshot)
            While Not recEnreg.EOF
                If (recEnreg!LaRegion <> "IDF" And recEnreg!LaRegion <> "RN") Then
                    sSQL = "insert into Ville values ('" & Replace(recEnreg!COMMUNE, "'", "''") & "','" & recEnreg!REGION_EXPLOITATION & "')"
                Else
                    sSQL = "insert into Ville values ('" & Replace(recEnreg!COMMUNE, "'", "''") & "','IDF-RN')"
                End If
                Call db.Execute(sSQL)
                Call recEnreg.MoveNext
                Me.ProgressBar1.Value = recEnreg.PercentPosition
                Me.LblPercent.Caption = Format(recEnreg.PercentPosition / 100, "0.00 %")
                Me.Repaint
            Wend
        
        ElseIf StrTable = "Sites" Then
            Set recEnreg = db.OpenRecordset("reqAlimSite", dbOpenSnapshot)
            While Not recEnreg.EOF
                sSQL = "insert into Site values ('" & recEnreg!NUM_SITE_THEORIQUE & "','" & Replace(recEnreg!COMMUNE, "'", "''") & "')"
                Call db.Execute(sSQL)
                Call recEnreg.MoveNext
                Me.ProgressBar1.Value = recEnreg.PercentPosition
                Me.LblPercent.Caption = Format(recEnreg.PercentPosition / 100, "0.00 %")
                Me.Repaint
            Wend
        End If
    ExitHandler:
        Me.ProgressBar1.Value = 100
        Me.LblPercent.Caption = 100 & " %"
        Call recEnreg.Close
        Call db.Close
        
    End Sub
    Si jamsis quelqu'un peut m'aider.

    Par avance je vous remercie.

    Marco.

  2. #2
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    481
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 481
    Points : 165
    Points
    165
    Par défaut
    Pour préciser un peut plus les choses, à un momment donner, la progressBar arrive tout pès de 100 et retombe environ à 97 % (au débug je me rend compte qu'il charge les 50 enregistrements suivants).

    Au bout d'un momment j'ai "not responding"...

    J'avoue que je ne sais pas trops comment m'en sortir.

  3. #3
    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
    Place des DoEvents dans ta boucle. Mais dans tous les cas, l'import risque d'être long puisque tu lances des tas de requêtes là où une seule sans VBA aurait suffit je pense

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    481
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 481
    Points : 165
    Points
    165
    Par défaut
    Merci Tofalu,

    Est ce que tu pourrais me suggérer une autre méthode s'il te plait ? J'avoue que face à un problème complexe, j'ai essayé de décomposer au maximum... Un autre problème aussi c'est que la barre de progression revient en arrière chaque fois qu'il arrive à la taille du lot des données qu'il prend... Comment résoudre cet autre aspect ?

    Est ce que tu pourrais préciser ta réponse s'il te plait ?

    Par avance merci.

    Marco.

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    481
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 481
    Points : 165
    Points
    165
    Par défaut
    Je continue mes rec herches sur le sujet du jour et il semblerait qu'en supprimant les index en début de traitement je devrais pouvoir gagner du temps.
    Est ce que quelqu'un pourrait m'aider ou aurait une autre idée ?

    Par avance merci.

    Marco.

  6. #6
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Points : 4 297
    Points
    4 297
    Par défaut
    il n'y a aucune raison de parcourir tous les enregistrements

    tu fais

    tant que pas fin fichier

    si monchamp=macondition
    alors j'ajoute
    loop


    il faut faire

    requête ajout dans table 1 mon recordset where monchamp = ma condition

    etc...

  7. #7
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    481
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 481
    Points : 165
    Points
    165
    Par défaut
    En fait si. Je veux ajouer tous les enregistrements, mais certaines valeurs (quand site=IDF ou site=RN alors mettre site=IDF-RN) et par ailleur, je risque d'avoir des doublons dans mes enregistrements. D'où le resume next en début... Mais là je sais pas trops comment accélérer tout ça... J'avais fait d'autres essais, mais il semble que dès que j'ai une jointure dns ma requête, Access refuse de faire l'ajout dans la table...

    Par avance merci de votre aide.

    Marco.

  8. #8
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 399
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 399
    Points : 2 221
    Points
    2 221
    Par défaut
    Bonjour,

    La syntaxe db.execute(sql) est plus de 45 fois plus lente que de passer par un recordset (rs.addnew,...rs.update)

    sur un test, 30000 ajouts avec le recordset : 300 ms et db.execute : 13500 ms !

    On peut donc optimiser le temps d'execution et peut être résoudre d'autres problèmes inhérents.

    Amicalement,

    Philippe

  9. #9
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 399
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 399
    Points : 2 221
    Points
    2 221
    Par défaut
    Pour compléter, voici le test réalisé qui n'a aucune valeur scientifique mais la différence de vitesse est significative je pense.

  10. #10
    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
    La syntaxe db.execute(sql) est plus de 45 fois plus lente que de passer par un recordset (rs.addnew,...rs.update)
    Bien entendu sur des accès multiple mais pour une seule insertion, il vaut mieux utiliser Execute. De plus je suis su qu'ici une seule requete INSERT INTO SELECT FROM serait suffisante

  11. #11
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 399
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 399
    Points : 2 221
    Points
    2 221
    Par défaut
    Bonjour Tofalu,


    Bien entendu sur des accès multiple mais pour une seule insertion, il vaut mieux utiliser Execute. De plus je suis su qu'ici une seule requete INSERT INTO SELECT FROM serait suffisante
    On est je pense ici dans le cas d'insertions multiples :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
     
    While Not recEnreg.EOF
                sSQL = "insert into Site values ('" & recEnreg!NUM_SITE_THEORIQUE & "','" & Replace(recEnreg!COMMUNE, "'", "''") & "')"
                Call db.Execute(sSQL)
                Call recEnreg.MoveNext
    ...
    me trompe-je ?

Discussions similaires

  1. [Access 2003] Tester avant d'importer des tables en vba
    Par texas2607 dans le forum VBA Access
    Réponses: 4
    Dernier message: 12/09/2007, 10h58
  2. [Access 2003] IMPORT DE TABLES EN VBA
    Par texas2607 dans le forum VBA Access
    Réponses: 0
    Dernier message: 11/09/2007, 15h28
  3. Importer une table de plusieurs mdb en VBA
    Par Jean-Marc68 dans le forum VBA Access
    Réponses: 9
    Dernier message: 16/03/2007, 13h55
  4. [VBA]Suppression de tables puis importation
    Par cciocc dans le forum Access
    Réponses: 2
    Dernier message: 06/06/2006, 10h12
  5. [VBA Excel] Importer des tables Access dans Excel
    Par loacast dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 06/12/2005, 11h44

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