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 :

VB6 et Acces 2013


Sujet :

VB 6 et antérieur

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Août 2002
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 89
    Points : 56
    Points
    56
    Par défaut VB6 et Acces 2013
    Bonjour à tous,

    J'ai un programme en VB6 qui utilise une basse de données Acces 2007.

    Actuellement pour accéder à ma base, j'utilise la fonction Opendatabase

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
        Call FileCopy(GLB_sCheminBase, GLB_sCheminBackup & "\" + sNomBackup)
        ' ouverture de la base toto.MDB en globale en mode partagé et lecture/écriture
        Set GLB_dbtoto = OpenDatabase(GLB_sCheminBase, False, False)
     
       avec 
                GLB_sCheminBase = "E:\toto.mdb"
                Public GLB_dbToto  as Database
    Puis dans le programme j'utilise la foncftion GLB_dbtoto.OpenRecordset("GRADES",dbOpenTable)

    J'ai convertir cette base en acces 2013.

    Mes questions

    Puis-je ouvrir avec VB6 ma base Acces 2013 ?
    Si oui comment ?
    Suis-je obliger d'installé acces 2013 sur mon pc ?

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Août 2002
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 89
    Points : 56
    Points
    56
    Par défaut
    Pour mes essais, j'ai fait un mini programme

    Voici le code

    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
     
    Private Sub cAcces2013_Click()
    '****************************************************
    '**   Lecture de d'une Base au format acces 2013
    '****************************************************
     
    Dim DB As Database
    Dim rdPalettes As Recordset
     
    Set GLB_dbGIRAUD = OpenDatabase("D:\toto\toto.accdb", False, False)
    Set rdProduction = GLB_dbGIRAUD.OpenRecordset("PRODUCTION", dbOpenTable)
     
    '****************************************************
    '**  Aficchage du resultat dans un Label
    '****************************************************
    Label1.Caption = "Lecture avec Acces 2013 : Secheur <== " & rdProduction("SECHEUR")
     
    End Sub
    Private Sub cAcces97_Click()
    '****************************************************
    '**   Lecture de d'une Base au format acces 97
    '****************************************************
     
    Dim DB As Database
    Dim rdPalettes As Recordset
     
    Set GLB_dbGIRAUD = OpenDatabase("D:\toto\toto.mdb", False, False)
    Set rdProduction = GLB_dbGIRAUD.OpenRecordset("PRODUCTION", dbOpenTable)
     
    '****************************************************
    '**  Aficchage du resultat dans un Label
    '****************************************************
    Label1.Caption = "Lecture avec Acces 97 : Secheur <== " & rdProduction("SECHEUR")
     
    End Sub

    Pas de problème pour accéder à basse acces 97.

    Mais j'ai ce message d'erreur "Erreur d'exécution '3343' : Format de base de données ('D:\toto\toto.accbd') non reconnu."
    Sur mon Pc, je n'ai pas acces 2013. Mais j'ai installé AccessDatabaseEngine.exe.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Août 2002
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 89
    Points : 56
    Points
    56
    Par défaut
    J'ai trouvé la solution a mon problème :

    Il faut installé le pilote office.
    Voici le Lien

    Puis aller dans Projet => réferences ...
    a) Désélectionner Microsoft DAO 3.6 object library
    b) Sélectionner Microsoft Office 14 access database engine object library

    Voici mon code programme corrigé

    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
     
    '============================================================================
    Private Sub cAcces2013_Click()
    '****************************************************
    '**   Lecture de d'une Base au format acces 2013
    '**
    '**
    '**    ==> Deselect Microsoft DAO 3.6 object library
    '**    ==> Select Microsoft Office 14 access database engine object library
    '**
    '**
    '****************************************************
     
    Dim db As Database
    Dim rd As Recordset
     
    Set db = OpenDatabase("D:\toto\toto.accdb", False, False)
    Set rd = db.OpenRecordset("PRODUCTION", dbOpenTable)
     
    '****************************************************
    '**  Aficchage du resultat dans un Label
    '****************************************************
    Label1.Caption = "Lecture avec Acces 2013 : Secheur <== " & rd("SECHEUR")
     
     
    End Sub
    Private Sub cAcces97_Click()
    '****************************************************
    '**   Lecture de d'une Base au format acces 97
    '**
    '**
    '**    ==> Microsoft DAO 3.6 object library
    '**
    '**
    '****************************************************
     
    Dim db As Database
    Dim rd As Recordset
     
    Set GLB_dbGIRAUD = OpenDatabase("D:\toto\toto.mdb", False, False)
    Set rd = GLB_dbGIRAUD.OpenRecordset("PRODUCTION", dbOpenTable)
     
    '****************************************************
    '**  Aficchage du resultat dans un Label
    '****************************************************
    Label1.Caption = "Lecture avec Acces 97 : Secheur <== " & rd("SECHEUR")
     
    End Sub
    J'ai testé dans ma vraie application cela marche aussi .

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

Discussions similaires

  1. [AC-2013] Littérature Acces 2013
    Par yannis3210 dans le forum Access
    Réponses: 1
    Dernier message: 08/05/2014, 23h03
  2. Erreur 3709 sous vb6 et acces
    Par SISGI dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 09/04/2014, 22h23
  3. SQL-DMO et VB6 pour accés à SQL 2008
    Par kikou_virago dans le forum Développement
    Réponses: 2
    Dernier message: 17/09/2008, 12h18
  4. [VB6] détection d'accès a internet via un réseau
    Par maddog2032 dans le forum VB 6 et antérieur
    Réponses: 25
    Dernier message: 19/11/2003, 23h01
  5. [VB6] [BDD] Optimisation de l'accès aux données
    Par LadyArwen dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 30/01/2003, 13h27

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