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 :

Création de liaison de table sous VB 6


Sujet :

VB 6 et antérieur

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 22
    Par défaut Création de liaison de table sous VB 6
    Bonjour à tous les passionnés :


    J'ai une application qui travaille avec un grande BDD et d'autres bases externes, toutes du type ACCESS 97

    Je voudrai avoir un code qui me permette d'attacher quelques tables des bases de données externes vers la grande.

    J'ai déjà fait cela en dur avec l'environnement ACCESS97, mais si je change l'application de répertoire, le chemin doit aussi changer, c'est pourquoi je veux le faire par code.

    Il n'y a aucun MDP pour ouvrir les BDD, je les ouvre simplement avec quelque chose du style

    set dbs=OpenDatabase(CheminBase)


    Merci d'avance

    Michel

  2. #2
    Expert confirmé
    Avatar de ProgElecT
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2004
    Messages
    6 132
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Décembre 2004
    Messages : 6 132
    Par défaut
    Moi je mettrais les bases de données dans un sous dossier de mon exécutable et j'utiliserais App.Path
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    set dbs=OpenDatabase(App.path & "\NomBD.mdb")
    :whistle:pourquoi pas, pour remercier, un :plusser: pour celui/ceux qui vous ont dépannés.
    saut de ligne
    OOOOOOOOO👉 → → Ma page perso sur DVP ← ← 👈

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 22
    Par défaut
    OK, mais ce n'est pas ce que je veux faire, car d'autres choses ne fonctionneront plus.
    En particulier des requêtes faites sur les tables attachées (gain de performances)


    Il n'y a que quelques lignes à taper, c'est simple (quand on sait le faire, comme d'habitude !! )

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

    Informations forums :
    Inscription : Juillet 2006
    Messages : 2 675
    Par défaut
    Je n'utilise jamais ADO, mais j'ai la solution en DAO

    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
    Private Sub InitTableLiee(TableAs As String, TableMdb As String)
      Dim Db As Database
      Dim TbDef As TableDef
      Set Db = OpenDatabase(Base)
      On Error Resume Next
      Db.TableDefs.Delete TableMdb
      On Error GoTo 0
      Set TbDef = Db.CreateTableDef(TableMdb)
      'Ligne suivante à personaliser
      TbDef.Connect = "ODBC;DSN=" & DSN.Text & ";DATABASE="
      TbDef.SourceTableName = TableAs
      On Error Resume Next
      Db.TableDefs.Append TbDef
      On Error GoTo 0
      Db.Close
    End Sub

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    22
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 22
    Par défaut
    Merci, j'ai trouvé aussi ceci sur un forum US, ça fonctionne super....
    Je l'ai adapté pour mon cas...

    Merci encore.


    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
    Sub LiaisonTablesExternes()
        On Error GoTo ERREUR
        Static i As Integer
     
        NomTable(1) = "CODEVILLES"
        NomTable(2) = "HISTORIQUE"
        NomTable(3) = "IMPORTCAISSE"
        NomTable(4) = "IMPORTVENTES"
        NomTable(5) = "IMPORTVENTESEDITIONCLIENTS"
     
     
     
        Set dbs = OpenDatabase(RepertoireBase & "GESTAB2000.MDB")
     
        For i = 1 To 5
            NomDeTable = NomTable(i)
            EffaceLiaisons
     
            Set Tables = dbs.CreateTableDef(NomDeTable)
            Tables.Connect = ";DATABASE=" & RepertoireBase & NomDeTable
            Tables.SourceTableName = NomDeTable
            dbs.TableDefs.Append Tables
        Next
        dbs.Close
        Exit Sub
    ERREUR:
        NumeroErreur = "ERREURIMPORT"
        FenetreErreur.Show 1
     
    End Sub
     
     
    Sub EffaceLiaisons()
        On Error Resume Next
        dbs.Execute ("DROP TABLE " & NomDeTable & "")
    End Sub

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

Discussions similaires

  1. Requête SQL avec création de table sous condition
    Par misig dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 04/11/2007, 08h58
  2. QueryTable et création de table sous oracle
    Par in dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 23/04/2007, 14h22
  3. [SQL-Server] Problème query création de tables sous PHP
    Par DjSoulz dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 27/03/2007, 22h18
  4. Réponses: 4
    Dernier message: 12/03/2007, 11h48
  5. Problème de création de table sous MySql
    Par ducamba dans le forum Requêtes
    Réponses: 2
    Dernier message: 21/06/2003, 09h59

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