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 :

Problème de commentaire SQL sur Excel [XL-2007]


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 21
    Points : 17
    Points
    17
    Par défaut Problème de commentaire SQL sur Excel
    Bonjour,
    Je travaille sur Excel 2007, il faut que j'exécute un script SQL à partir de Excel.
    Mon code marche bien en cliquant sur un bouton en Excel je peux extraire des données d'une Base SQL Server avec des Macros en utilisant ODBC.
    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
     
    Public Function FileToSQL(strPath As String) As String
        Dim strRecord   As String
        Dim SQLStatement As String
        Dim ScriptLine As String
        Dim StopOrResume As Integer
        Open strPath For Input As #1
        Do While Not EOF(1)
        SQLStatement = ""
          Line Input #1, ScriptLine
          ScriptLine = Trim(ScriptLine)
              SQLStatement = SQLStatement & " " & ScriptLine
              Do While (Not EOF(1)) And (ScriptLine <> "") And (Right(SQLStatement, 1) <> ";")
                  Line Input #1, ScriptLine
                  ScriptLine = Trim(ScriptLine)
                  SQLStatement = SQLStatement & " " & ScriptLine
              Loop
              SQLStatement = Trim(SQLStatement)
            FileToSQL = FileToSQL & SQLStatement
        Loop
        Close #1
    End Function
    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
     
    Sub Test_Emprunt()
       ' Déclarer l'objet QueryTable
    Dim qt As QueryTable
    ' Appel au script contenant la requête
    sqlstring1 = FileToSQL("c:\test.sql")
    ' Mettre en place la référence d'une connexion ODBC
    ' Vous pouvez laisser le nom et mot de passe vide pour l'authentification
    connstring1 = _
     "ODBC;DSN=pubs;UID=;PWD=;Database="
     
    'La mise en œuvre de la connexion, exécution de la requête, 
    ‘ Et l’ajout des résultats de la feuille ‘Data1’  à partir de la cellule  ‘A3’
    With Sheets("Data1").QueryTables.Add(Connection:=connstring1, Destination:=Range("Data1!A3"), Sql:=sqlstring1)
     .Refresh
    End With
    End Sub
    Mon problème c'est quand j'ai des commentaires de type "-- Commentaire" ma requête ne s'exécute pas et j'ai un message d'erreur.

    Avec les commentaire de type "/*Commentaire*/" ça marche bien sauf que dans la société ou j'effectue mon stage ils ont déjà des scripts où ils utilisent des commentaires de type "-- Comment".

    J'ai essayé de trouver la solution mais je n'arrive pas.

    Est ce que quelqu'un à une idée pour m'aider S.V.P

    Merci d'avance

  2. #2
    Membre expérimenté Avatar de mayekeul
    Inscrit en
    Août 2005
    Messages
    1 369
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 1 369
    Points : 1 665
    Points
    1 665
    Par défaut
    bonjour,

    tu peux essayer de sauter les commentaires

    simplement comme ça non?

    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
     
    Public Function FileToSQL(strPath As String) As String
        Dim strRecord   As String
        Dim SQLStatement As String
        Dim ScriptLine As String
        Dim StopOrResume As Integer
        Open strPath For Input As #1
        Do While Not EOF(1)
        SQLStatement = ""
          Line Input #1, ScriptLine
          ScriptLine = Trim(ScriptLine)
              SQLStatement = SQLStatement & " " & ScriptLine
              Do While (Not EOF(1)) And (ScriptLine <> "") And (Right(SQLStatement, 1) <> ";")
                  Line Input #1, ScriptLine
                  ScriptLine = Trim(ScriptLine)
                  if not left(scriptline,2)="--" then SQLStatement = SQLStatement & " " & ScriptLine
              Loop
              SQLStatement = Trim(SQLStatement)
            FileToSQL = FileToSQL & SQLStatement
        Loop
        Close #1
    End Function

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 21
    Points : 17
    Points
    17
    Par défaut
    Merci beaucoup ça marche très bien

    Tu m'a sauver la vie

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

Discussions similaires

  1. Problème d'installation Sql sur vista
    Par wperle dans le forum Windows Vista
    Réponses: 2
    Dernier message: 04/02/2008, 11h30
  2. [SQL] Problème de requête SQL sur une condition avec OR
    Par vinzginz dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 12/10/2007, 15h31
  3. Problème : Recherche de valeur sur Excel
    Par tzehani dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 10/08/2007, 15h45
  4. Problème : Recherche de valeur sur Excel
    Par tzehani dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 07/08/2007, 16h04
  5. problème de requête SQL sur 3 tables pour un while
    Par carmen256 dans le forum Requêtes
    Réponses: 3
    Dernier message: 13/04/2006, 16h55

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