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 :

Compter le nombre de tables dans la base


Sujet :

VBA Access

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Septembre 2007
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 99
    Par défaut Compter le nombre de tables dans la base
    Bonjour,

    A partir de VBA Excel, j'ouvre une connection vers une database Access.

    J'aimerais ensuite passer en revue toutes les tables de la base et sauver par exemple leur nom dans un vecteur.

    Je pensais faire un truc du genre suivant, mais le type Table n'est apparamment pas reconnu.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
        Dim myTables() As String
        Dim myTable As ?????? adCmdTable ou Table ????
        Dim myCount As Integer
        myCount = 0
        For Each myTable In myDB.Table
            myCount = myCount + 1
            myTables(myCount) = myTable.Name
         Next myTable

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

    As-tu été consulté la FAQ Access ? Car je suis sûr que tu trouveras ton bonheur ici : http://access.developpez.com/faq/?pa...lds#NomChpsTbl

    Un exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Public Sub test()
    Dim Db As DAO.Database
    Set Db = CurrentDb
        MsgBox Db.TableDefs.Count
    End Sub
    Philippe

  3. #3
    Membre confirmé
    Inscrit en
    Septembre 2007
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 99
    Par défaut
    Merci pour le lien
    Il y a effectivement pas mal d'info.

    Cependant, je ne sais pas utiliser "Currentdb" car j'ouvre "fictivement" la base Access à partir d'excel.

    Quand j'utilise le code suivant, il me met chaque fois "Object required"
    Comment lui spécifier la base sur laquelle il doit travailler?
    Merci


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
     
     
        Dim myDB As DAO.Database
        Dim myDBname As String
     
        myDBname = "DB_MKTANALYSIS.mdb"
        Set myDB = Workspace.OpenDatabase(myDBname, False, True, "MS Access")

  4. #4
    Invité
    Invité(e)
    Par défaut
    Re

    As-tu consulté la FAQ Excel ? Comme cet exemple : http://excel.developpez.com/faq/inde...ortTableAccess

    Il faut référencer la bibliothèque DAO 3.6

    Philippe

  5. #5
    Expert éminent

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Par défaut
    Bonjour,

    Workspace n'est déclaré nulle part.

    Voici un exemple :

    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
    Sub test()
    Dim oE As DAO.DBEngine
    Dim oWs As DAO.Workspace
    Dim oDb As DAO.Database
    Dim oTbl As DAO.TableDef
    Dim i As Integer
     
    Set oE = New DAO.DBEngine
    Set oWs = oE.CreateWorkspace("MyWorkSpace", "admin", "", dbUseJet)
    Set oDb = oE.OpenDatabase("C:\tutoMCD.accdb", True)
    For Each oTbl In oDb.TableDefs
        If (oTbl.Attributes And dbSystemObject) = 0 Then
            i = i + 1
        End If
    Next
     
    oDb.Close
     
    Set oDb = Nothing: Set oE = Nothing
     
    MsgBox "Il y a " & i & " tables dans la base de données"
    End Sub
    A noter que si on souhaite ouvrir une base au format 2007 ou 2010, il est nécessaire de remplacer la référence Microsoft DAO par Microsoft Office 12.0 (ou 14.0) Access Database Engine Object

  6. #6
    Membre confirmé
    Inscrit en
    Septembre 2007
    Messages
    99
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 99
    Par défaut
    OK merci

    Si je met ce code-ci, cela semble résoudre mon problème

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     
    Set myDB = DAO.OpenDatabase(myDBname, False, True, "MS Access")

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

Discussions similaires

  1. Compter le nombre d'enregistrement dans une table selon un critere
    Par Angelo91 dans le forum Requêtes et SQL.
    Réponses: 8
    Dernier message: 18/08/2008, 12h05
  2. [SQL] Compter le nombre d'occurences dans une table par valeur
    Par SpaceFrog dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 16/04/2008, 17h22
  3. nombre de tables dans une base
    Par 080983 dans le forum SQL
    Réponses: 11
    Dernier message: 22/08/2007, 23h02
  4. Compter le nombre de colonne dans une table
    Par Coin dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 01/12/2006, 16h03
  5. [MySQL] compter nombre de table dans une base
    Par stephan55 dans le forum Langage SQL
    Réponses: 5
    Dernier message: 16/06/2006, 18h31

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