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] Integrer une requete Microsoft query dans VBA Excel


Sujet :

Macros et VBA Excel

  1. #1
    Membre régulier
    Inscrit en
    Mars 2008
    Messages
    257
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 257
    Points : 111
    Points
    111
    Par défaut [E-03] Integrer une requete Microsoft query dans VBA Excel
    Bonjour,

    je desire integrer cette requete SQL que j'ai creer a partir de Microsoft query et l'utiliser directement dans une macro VBA afin de l'executer a partir de la. C'est a dire que je veux tout simplement faire executer cette requete directement a partir d'une macro au lieu de lancer la requete microsoft query a l'ouverture de mon fichier.
    Est-ce possible ? Si oui, pourriez-vous m'aider a accomplir cela svp.

    Voici ma requete :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT asset.long_descp, ast_book.ast_id, ast_book.ast_book_nbr, ast_book.ast_entity_id, ast_book.ast_tot_cost, ast_book.ltd_depr_amt, ast_book.current_depr_amt, ast_book.depr_status_code, ast_book.ytd_depr_amt
    FROM DBSfast.dbo.asset asset, DBSfast.dbo.ast_book ast_book
    WHERE ast_book.ast_entity_id = asset.ast_entity_id AND ast_book.ast_id = asset.ast_id AND ((ast_book.depr_status_code='F') AND (asset.ast_id Like '8%') OR (ast_book.depr_status_code='D') AND (asset.ast_id Like '8%') OR (ast_book.depr_status_code='N') AND (asset.ast_id Like '8%'))
    Merci pour votre aide d'avance !

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    753
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 753
    Points : 855
    Points
    855
    Par défaut
    C'est une requête pour quel type de base de données?

  3. #3
    Membre régulier
    Inscrit en
    Mars 2008
    Messages
    257
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 257
    Points : 111
    Points
    111
    Par défaut
    C'est une base de donnee Sybase!

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    753
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 753
    Points : 855
    Points
    855
    Par défaut
    Désolé je n'y connais strictement rien, mais je pense que tu peux trouver la réponse à ta question soit sur les tutos/FAQ de Sybase sur le site, soit sur la section Sybase des forums.

  5. #5
    Expert éminent
    Avatar de cafeine
    Inscrit en
    Juin 2002
    Messages
    3 904
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 3 904
    Points : 6 781
    Points
    6 781
    Par défaut
    Hello,

    je ne connais pas Sybase, mais j'imagine que tu dois pouvoir utiliser ADO ou DAO pour te connecter à cette base et récupérer les données d'un recordset dépendant de ton instruction SQL.

  6. #6
    Membre régulier
    Inscrit en
    Mars 2008
    Messages
    257
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 257
    Points : 111
    Points
    111
    Par défaut
    Je vais regarder au niveau de ADO ! Merci

  7. #7
    Nouveau Candidat au Club
    Inscrit en
    Juin 2008
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Juin 2008
    Messages : 1
    Points : 1
    Points
    1
    Par défaut
    J'utilise personnellement le syntaxe suivant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
      With ActiveSheet.QueryTables("Toto")
     
            .Connection = ConnectionIDString
            .Sql = QueryText
            .PreserveFormatting = False
            .AdjustColumnWidth = True
            .Refresh
     
        End With
    où QueryText est le texte de ta requête et Toto - le nom de la plage de résultats prédéfinie (utiliser la méthode add pour la créer la 1ère fois)

    Je ne sais pas si c'est ce que tu recherches...

  8. #8
    Membre émérite Avatar de Godzestla
    Homme Profil pro
    Chercheur de bonheur
    Inscrit en
    Août 2007
    Messages
    2 392
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : Belgique

    Informations professionnelles :
    Activité : Chercheur de bonheur
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 2 392
    Points : 2 985
    Points
    2 985
    Par défaut
    Bonjour Mimosa77,

    rien de tel que l'enregistreur de macro pour ta problématique.

    Via Data -> Import External data -> Import data ou New database Query

    Et le code généré t'en dira long sur ce que tu cherches.
    Surtout si ta requète Microsoft SQL (DQY) existe déjà.

  9. #9
    Membre averti
    Inscrit en
    Octobre 2008
    Messages
    273
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Octobre 2008
    Messages : 273
    Points : 323
    Points
    323
    Par défaut
    Bonjour,
    J'ai fait des requêtes de ce type en utilisant l'enregistreur de macro et en faisant ma requête par msquery et ça marche très bien.
    J'ai testé sur du mysql et du postgré.

    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
    With ActiveSheet.QueryTables.Add(Connection:="ODBC;DSN=chaine connexion;uid=utilisateur;pwd=mot de passe", _
            Destination:=Range("A1"))
            .CommandText = Array( _
            SELECT * FROM toto ..... etc _
            )
            .Name = instruction
            .FieldNames = True
            .RowNumbers = False
            .FillAdjacentFormulas = False
            .PreserveFormatting = True
            .RefreshOnFileOpen = False
            .BackgroundQuery = True
            .RefreshStyle = xlInsertDeleteCells
            .SavePassword = False
            .SaveData = True
            .AdjustColumnWidth = True
            .RefreshPeriod = 0
            .PreserveColumnInfo = True
            .Refresh BackgroundQuery:=False
     
        End With
    Tu peux même mettre une variable à la place de la requête.

    EDIT : grillé ...

  10. #10
    Membre régulier
    Inscrit en
    Mars 2008
    Messages
    257
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 257
    Points : 111
    Points
    111
    Par défaut
    Merci beaucoup a tous.. effectivement, en utilisant l'enregistreur de macro, ca repond bien a mon besoin.

    Merci a tous de votre aide.

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

Discussions similaires

  1. Réponses: 14
    Dernier message: 10/01/2007, 10h12
  2. Comment executer une requete sql delete dans une jsp ?
    Par DarkWark dans le forum Servlets/JSP
    Réponses: 3
    Dernier message: 24/05/2006, 16h59
  3. [WIN32][D2005] Integrer une librairie C/C++ dans Delphi
    Par ZeGothMan dans le forum Langage
    Réponses: 8
    Dernier message: 30/03/2006, 13h56
  4. Réponses: 3
    Dernier message: 02/11/2005, 02h45
  5. Passage d'une requete en paramètre dans un delete
    Par jlamazou dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 03/08/2005, 17h58

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