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

Macros et VBA Excel Discussion :

Lancer une requete ACCESS depuis une macro Excel


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Inscrit en
    Novembre 2010
    Messages
    92
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 92
    Points : 54
    Points
    54
    Par défaut Lancer une requete ACCESS depuis une macro Excel
    Bonjour à tous,

    Pourriez-vous svp me donner des pistes pour le probleme suivant : je cherche à lancer une requete acess de création de table (c'est-à-dire qui crée une table access dans la même base access) depuis une macro excel (ou du code vba excel).

    Autrement dit : j'ai une base de données access dans laquelle figure une requête dont l'objectif est de crée une table dans cette même base access. Par ailleurs j'ai un classeur excel et je voudrais dans ce classeur crée une macro qui lance cette requête dans la base access, avec comme conséquence de créer (ou d'écraser) une table dans cette même base access.

    J'ai bien lu dans les FAQ le sujet sur QueryTables mais ça ne correspond pas totu à fait à mon sujet.


    Merci d'avance aux contributeurs.

    Stargates

  2. #2
    Expert éminent
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Points : 6 871
    Points
    6 871
    Par défaut
    Bonsoir,

    Teste ce qui suit sur une base test pour te donner une piste.
    Il te faut cocher les références :
    "Microsoft ActiveX Data Objects 6.0 Library" et "Microsoft ADO Ext. 2.8 for DDL and Security"
    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
     
    Private Sub ConnecterBase(ConnectBD As ADODB.Connection, _
                              Fichier As String)
     
        Set ConnectBD = New ADODB.Connection
     
        With ConnectBD
     
            .Provider = "Microsoft.Jet.OLEDB.4.0"
            .ConnectionString = Fichier
            .Open
     
        End With
     
    End Sub
     
    Private Sub CreerTable()
     
        Dim ConnectBD As ADODB.Connection
        Dim Catalogue As ADOX.Catalog
        Dim ChaineSQL As String
        Dim NomBase As String
     
        Set Catalogue = New ADOX.Catalog
     
        'adapter le chemin
        NomBase = "D:\Dossier1\MaBase.mdb"
     
        ConnecterBase ConnectBD, NomBase
     
        Catalogue.ActiveConnection = ConnectBD
     
        'définir la chaine SQL, ici 4 champs
        ChaineSQL = "CREATE TABLE NomDeLaTable ( "
        ChaineSQL = ChaineSQL & "ID CHAR(10) WITH COMP PRIMARY KEY, "
        ChaineSQL = ChaineSQL & "Nom CHAR(20) WITH COMP NULL, "
        ChaineSQL = ChaineSQL & "Prenom CHARACTER(20) NOT NULL, "
        ChaineSQL = ChaineSQL & "Age DATE); "
     
        With ConnectBD
     
            .Execute ChaineSQL
            .Close
     
        End With
     
        Set Catalogue = Nothing
        Set ConnectBD = Nothing
     
    End Sub
    Hervé.

  3. #3
    Membre du Club
    Inscrit en
    Novembre 2010
    Messages
    92
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 92
    Points : 54
    Points
    54
    Par défaut
    OK, merci Hervé, je vais tester.

    Mais je comprends qu'il faut que je reprenne le script SQL de ma requêtre de création de table dans la ligne de commande la macro. N'y a-t-il pas moyen directement par une commande de lancer la requêtre access en utilisant son nom (sans avoir à remettre tout le script SQL qu'elle contient) ? En effet ma requête contient prêt de 40 champs, avec des liasions entre plusieurs tables, d'où un script SQL assez long....

    En tout cas merci pour la solution

    Stargates

Discussions similaires

  1. Transfert d'une table interne sur une table Access depuis VB
    Par mathieuch dans le forum VBA Access
    Réponses: 37
    Dernier message: 05/03/2009, 10h48
  2. nombre trop long depuis une requete access
    Par db48752b dans le forum ASP
    Réponses: 5
    Dernier message: 18/11/2008, 13h49
  3. Récuperation d'une valeur d'une requete access depuis excel
    Par titeZ dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 14/04/2008, 11h15
  4. [Access] Filtrer une liste déroulante depuis une autre
    Par Marie_2116 dans le forum Access
    Réponses: 20
    Dernier message: 24/08/2007, 17h19
  5. [VBA] [ACCESS] Accès à une requete Access via VBA
    Par Yanmeunier dans le forum Access
    Réponses: 3
    Dernier message: 16/03/2006, 11h48

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