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 :

[E-03] Récupération des données d'une BD Access 02 via excel


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Inscrit en
    Mars 2009
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 27
    Points : 27
    Points
    27
    Par défaut [E-03] Récupération des données d'une BD Access 02 via excel
    Bonjour

    Je cherche à récupérer des données d'une base de données access. Malgré mon bon vouloir et mes nombreuses recherches, je n'y arrive toujours pas.

    Voici le code que j'ai écrit

    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
    Function GetInfo(U As String, T As String, S As String)
    
    Dim sql As String
    Dim acApp As Access.Application
    Dim chemin As String
    Dim nmt As String
    
    xml = Value1
    'nom de la table
    nmt = Value2
    ' Démarrer Access
    Set acApp = New Access.Application
     
    ' Ouvrir la base de données concernée
    acApp.OpenCurrentDatabase (chemin & "nom.mdb")
    
    
        
        sql = "SELECT C FROM  [" & nmt & " ] WHERE S = " & Chr(34) & U & Chr(34) & " and Sc=" & Chr(34) & S & Chr(34)
            
            Get Info=currentDb.execute(sql)
    End Function
    Par contre vba n'a pas trop l'air d'accord avec la ligne rouge. sauriez vous pourquoi? en plus, lorsqu'il exécute la requête sql, il ne trouve pas la table. l'aurais je mal désignée?

    Merci pour votre aide

  2. #2
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Bonjour,

    Je ne sais pas si ça t'aidera, mais regardes toujours :
    http://www.info-3000.com/vbvba/vbainteractionaccess.php
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  3. #3
    Nouveau membre du Club
    Inscrit en
    Mars 2009
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 27
    Points : 27
    Points
    27
    Par défaut [E-03] plus de détails
    J'ai réussi à cibler le problème
    le code plante à cause de la requête
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    sql = "SELECT C FROM  [" & nmt & "] WHERE S= '" & Sc & "' AND (Un = '" & U& "')"
    ce qui est bizarre c'est que la code plante lorsque j'ajoute la 2ème condition. Avec seulement la première ça marche très bien.
    l'erreur qui s'affiche est "No Value given for one or more required parameters"
    Es ce dû à la requête ou à la base de données elle même?
    Merci pour votre aide

  4. #4
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    d'après les exemples que j'ai consulté, sans garantie je te propose d'essayer

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    sql = "SELECT C FROM  [" & nmt & "]" 
    sql = sql & WHERE S= "Sc" & " AND (Un = " & U & ")"
    La syntaxe sera surement à revoir
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  5. #5
    Nouveau membre du Club
    Inscrit en
    Mars 2009
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 27
    Points : 27
    Points
    27
    Par défaut
    Bonjour
    Merci pour ta réponse.
    Le code ne fonctionne toujours pas. Ca bloque niveau requête. Lorsque je supprime la 2e condition, tout marche bien et le recordset récupère une valeur. Je ne comprends pas pourquoi la 2e condition fait planter le tout...
    Pourtant, après de nombreuses recherches j'ai cru trouver la bonne syntaxe.
    Je ne sais pas si c'est lié à la strucuture du champ en question dans access.

Discussions similaires

  1. Réponses: 6
    Dernier message: 28/10/2014, 12h19
  2. Réponses: 0
    Dernier message: 09/03/2012, 23h41
  3. Récupération des données d'une base access sur réseau
    Par fishingman dans le forum VB.NET
    Réponses: 3
    Dernier message: 24/06/2011, 09h13
  4. [MySQL] problème de récupération des données d'une requête
    Par maniaco_jazz dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 19/02/2007, 12h12
  5. [MySQL] Problème de récupération des données dans une fonction
    Par highman dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 26/10/2006, 20h04

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