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 :

Comment Excel importe des données d'une base de données ? [XL-2010]


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2012
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Octobre 2012
    Messages : 33
    Points : 29
    Points
    29
    Par défaut Comment Excel importe des données d'une base de données ?
    Bonjour à tous,

    J'ai l'impression de ne pas être très loin de la réussite et j'ai besoin d'un coup de pouce de l'un de vous svp.

    J'ai un tableau Excel composé de 4 colonnes, les 3 premières sont remplies et la dernière est vide. En fait, cette dernière colonne peut être remplie grâce à une connexion aux tables de ma base de données.
    J'ai trouvé le moyen de dire à Excel "lis ce qu'il y a dans la colonne A, la colonne B et la colonne C pour l'insérer dans la query". Je pense qu'il ne me reste plus que l'étape "compare ces 3 informations avec la base de données et copie le résultat de la query dans la colonne D" ... c'est là que j'ai besoin de vous.


    Mon tableau ressemble à ça :

    A --------B ----- C ------- D
    Aliquot1 Test1 Resultat1
    Aliquot2 Test2 Resultat2
    Aliquot3 Test3 Resultat3

    Et voici le code que j'ai déjà é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
    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
    51
    52
    53
    54
    Sub Find_testID()
     
    Dim rnCell As Range
    Dim rnArea As Range
    Dim rsResult As Recordset
    Dim strCon As String
    Dim objCon As New Connection
    Dim sSQL As String
    Dim strAliq As String
    Dim strTest As String
    Dim strResult As String
    Dim strTestID As String
    Dim intRow As Integer
     
    strCon = "Provider=MSDAORA;Data Source=xxxx;User ID=xxxx;Password=xxxx"
     
    objCon.Open strCon
     
    Set rnArea = Worksheets(3).Range("info")
     
    For Each rnCell In rnArea
        strAliq = Cells(rnCell.Row, 1).Value
        strTest = Cells(rnCell.Row, 2).Value
        strResult = Cells(rnCell.Row, 3).Value
    If intRow <> rnCell.Row Then
         intRow = rnCell.Row
     
    sSQL = "SELECT aliquot.name,"
    sSQL = sSQL + "       test.name,"
    sSQL = sSQL + "       result.result,"
    sSQL = sSQL + "       test.test_id"
    sSQL = sSQL + "  FROM aliquot,"
    sSQL = sSQL + "       test,"
    sSQL = sSQL + "       result"
    sSQL = sSQL + " WHERE aliquot.aliquot_id = test.aliquot_id"
    sSQL = sSQL + "   AND test.test_id = result.test_id"
    sSQL = sSQL + "   AND aliquot.name = '" & strAliq & "'"
    sSQL = sSQL + "   AND test.name = '" & strTest & "'"
    sSQL = sSQL + "   AND result.result = '" & strResult & "'"
     
                Set rsResult = objCon.Execute(sSQL)
     
                rsResult.Close
                rsResult.CursorType = adOpenStatic
                rsResult.Open
                rsResult.MoveFirst
          Else: rsResult.MoveFirst
    End If
    strTestID = Cells(rnCell.Row, 4).Value
    Next
     
    objCon.Close
     
    End Sub
    Si je remplace dans la query la valeur de la première ligne, j'obtiens ça:

    Aliquot - Test -- Resultat --- TestID
    Aliquot1 Test1 Resultat1 123547

    Je serai donc ravi de voir apparaître dans la colonne D le 123547

    Vu qu'il y a plus de 4000 lignes, j'aimerai faire tourner une macro qui se connecte directement à la base de données pour copier le TestID dans la colonne D. Mais quand je fais ça, il ne se passe rien.

    Comment puis-je dire dans la macro "mets-moi le TestID dans la colonne D puis passe à la ligne suivante".

    Je vous remercie pour vos conseils.
    - Henri

  2. #2
    Expert éminent sénior
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 203
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 203
    Points : 14 354
    Points
    14 354
    Par défaut
    Bonjour,
    Sans garantie (je n'ai jamais travaillé avec plusieurs tables), mets :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Cells(rnCell.Row, 4).Value = rsResult.Fields("test_id")
    après :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set rsResult = objCon.Execute(sSQL)
    Cordialement.

    Daniel

    La plus perdue de toutes les journées est celle où l'on n'a pas ri. Chamfort

  3. #3
    Membre expérimenté
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    747
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 747
    Points : 1 332
    Points
    1 332
    Par défaut
    Bonjour h12enri, Bonjour Daniel,

    Si l'un des champs récupérés dans tes cellules peut contenir une apostrophe, pense à la doubler avant de l'injecter dans le SQL

    modifie

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
        strAliq = Cells(rnCell.Row, 1).Value
        strTest = Cells(rnCell.Row, 2).Value
        strResult = Cells(rnCell.Row, 3).Value
    en

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
        strAliq = replace(Cells(rnCell.Row, 1).Value, "'", "''")
        strTest = replace(Cells(rnCell.Row, 2).Value, "'", "''")
        strResult = replace(Cells(rnCell.Row, 3).Value, "'", "''")

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2012
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Octobre 2012
    Messages : 33
    Points : 29
    Points
    29
    Par défaut
    Super les gars,

    Un Grand Merci pour votre aide. J'y suis parvenu!

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

Discussions similaires

  1. [XL-2010] sélection des données depuis une base de données depuis une autre feuille
    Par Learning everyday dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 05/11/2014, 10h14
  2. Importer le contenu d'une base de données sur une autre
    Par minelissimo dans le forum Installation
    Réponses: 1
    Dernier message: 26/09/2013, 13h44
  3. Réponses: 1
    Dernier message: 01/12/2012, 09h47
  4. inserer les données d'une base de données dans une autres?
    Par enstein8 dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 14/10/2011, 13h33
  5. Réponses: 5
    Dernier message: 10/01/2008, 08h47

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