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 :

Exécuter code dans base A depuis base B


Sujet :

Access

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert

    Homme Profil pro
    Inscrit en
    Janvier 2006
    Messages
    1 186
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 186
    Par défaut Exécuter code dans base A depuis base B
    Bonjour,

    J'ai une base de données Access "A" dont les données sont mises à jour grâce à des fichiers plats (3 fichiers quotidiens de +/- 100000 lignes).
    Lors de reprise de données, je remets à jour les données avec tous les fichiers existants. La base grossit vite et je suis obligé de la compacter...
    Problème : je ne peux pas lancer le travail sans être derrière le poste.
    J'ai donc pensé travailler en tables liées, pour pouvoir commander un compactage.
    Une base "B" pilote le chargement des données dans la base "A". Ceci permet de commander le compactage de la base "A"
    Problème : les temps de traitement des données dans la base "A" sont trèèèès (trop) longs.
    Y-a-t-il un moyen de lancer le code d'intégration des données de la base "A" depuis la base "B" ?

    Genre : depuis "B", j'ouvre "A", je lance le code de "A" pour intégrer un lot de fichiers, je ferme "A", je compacte "A", ...

    Merci.
    [Access] Les bases du débogage => ici

  2. #2
    Membre émérite
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    710
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 710
    Par défaut
    Salut et bienvenu sur le forum,

    Je ne sais pas quel est la syntaxe pour executer un sub d'une autre base mais j'avais trouvé une "bidouille" pour le faire (ouvrir un formulaire je sais faire).

    En fait dans ta base A tu crée un formulaire (vide, indépendant ...) qui n'a qu'un événement sur ouverture :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Private Sub Form_Open(Cancel As Integer)
    DeVloP
    DoCmd.Close acForm, Me.Name
     
    End Sub
    Ainsi sur ouverture tu execute ton sub DeVloP puis tu ferme le formulaire.

    Dans ta base B tu fais qqchose comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    Sub DeVloP_B()
    Dim BaseA As Object
    Set BaseA = GetObject("d:\dvp.mdb")
    BaseB.Application.DoCmd.OpenForm "formulaire1"
    BaseB.Application.Quit
    Set BaseA = Nothing
    CompactDatabase "d:\dvp.mdb", "d:\dvp_compacté.mdb"
    End Sub
    Voila, c'est loin d'être propre mais cela t'aidera peut-être

    A+

  3. #3
    Expert confirmé
    Avatar de Arkham46
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    5 865
    Détails du profil
    Informations personnelles :
    Localisation : France, Loiret (Centre)

    Informations forums :
    Inscription : Septembre 2003
    Messages : 5 865

  4. #4
    Membre Expert

    Homme Profil pro
    Inscrit en
    Janvier 2006
    Messages
    1 186
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 186
    Par défaut
    Merci,

    J'ai trouvé une solution. Ca donne à peu près ça :
    Dim appAccess As Access.Application
    ...
    Set appAccess = CreateObject("Access.Application.8")
    appAccess.OpenCurrentDatabase iStr_NomBaseDonneesSrc, False
    appAccess.DoCmd.OpenForm "-= Pilotage =-"
    Do
    iLng = iLng + 1
    ecritStatus "Traitement des données du " & gDat_DateTraitement & " ..."
    ecritLog "Début de traitement des données du " & gDat_DateTraitement
    appAccess.Run "traite", gDat_DateTraitement, gDat_DateTraitement
    ecritLog "Fin de traitement des données du " & gDat_DateTraitement
    If Int(iLng / 10) = iLng / 10 Then
    appAccess.CloseCurrentDatabase
    DoEvents
    appAccess.Quit acQuitSaveNone
    DoEvents
    Set appAccess = Nothing
    ecritStatus "Compactage en cours ..."
    Compactage
    Set appAccess = CreateObject("Access.Application.8")
    appAccess.OpenCurrentDatabase iStr_NomBaseDonneesSrc, False
    appAccess.DoCmd.OpenForm "-= Pilotage =-"
    End If
    ...
    [Access] Les bases du débogage => ici

Discussions similaires

  1. [AC-2010] Aide crea table liées dans base dorsale depuis base frontale
    Par lbar012001 dans le forum VBA Access
    Réponses: 1
    Dernier message: 12/06/2013, 13h17
  2. Exécuter code dans un autre fichier
    Par Mwoua_n7 dans le forum Langage
    Réponses: 6
    Dernier message: 02/07/2012, 14h20
  3. [AC-2003] creer une table en vba depuis base frontale sur base dorsale
    Par morinxav1 dans le forum VBA Access
    Réponses: 9
    Dernier message: 16/03/2012, 21h29
  4. [Toutes versions] Lancer macro base B depuis base A
    Par nietzsche64 dans le forum VBA Access
    Réponses: 2
    Dernier message: 06/12/2011, 15h20
  5. mise à jour base distante depuis base locale
    Par jmsch dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 15
    Dernier message: 07/04/2011, 23h06

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