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

Bases de données Delphi Discussion :

Création dynamique TADOConnection


Sujet :

Bases de données Delphi

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2002
    Messages : 89
    Points : 64
    Points
    64
    Par défaut Création dynamique TADOConnection
    Bonjour,
    J'écris un programme dans le fichier .DPR de mon projet et j'ai une procédure qui doit créer un composant dynamique "TADOConnection" :

    uses
    ADODB, DB;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    var
      Connection : TAdoConnection;
    begin
      Connection := TADOConnection.Create(nil);
      Connection.ConnectionString := ConnStrProvider + ConnStrData + PathApp + ConnStrInfo;
      Connection.Open;
    ....
      Connection.Free;
    Lorsque j'arrive sur le "Connection := TADOConnection.Create(nil);
    ", Delphi me génère une erreur d'exception "Exception EOleSysError dans le module Test.exe dans 0006242D.
    CoInitialize n'a pas été appelé."

    Il est a noter que si je fais ça dans une UNIT standard de Delphi, cela fonctionne parfaitement...

    Alors, qu'est-ce qui ne va pas ?

    Merci de votre aide
    Delphi 7 Pro, Visual Basic, Borland C++, WinXP, Win7

  2. #2
    Membre expérimenté

    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    897
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2004
    Messages : 897
    Points : 1 561
    Points
    1 561
    Par défaut
    Jette un coup d'oeil sur

    http://www.developpez.net/forums/viewtopic.php?t=176745

    Inspire toi de cela...

    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
     
    // exécute une requête à partir d'un TADOCommand 
    // renvoie TRUE si aucune erreur FALSE dans le cas contraire 
    function executeSQL(connexionString, requete: string):boolean; 
    var ADOC: TADOCommand; 
        indic: boolean; 
    begin 
      try 
        indic := true; 
        ADOC := TADOCommand.Create(nil); 
        ADOC.ConnectionString := connexionString; 
        ADOC.CommandText := requete; 
        try 
          ADOC.Execute; 
        except 
          indic := false; 
        end; 
      finally 
        ADOC.Free; 
        result := indic; 
      end; 
    end;
    Pensez à utiliser les tags dans le titre.
    Avant de poser une question reportez-vous à la FAQ Delphi
    Respectez les règles du forum.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2002
    Messages : 89
    Points : 64
    Points
    64
    Par défaut
    Merci de la réponse mais si j'utilise le TADOCommand, ça ne change rien...

    J'ai essayé dans une UNIT et là y'a pas de problème.

    Pascal, essaie d'écrire la procédure dans le fichier .DPR et tu verras que ça bug...
    Delphi 7 Pro, Visual Basic, Borland C++, WinXP, Win7

  4. #4
    Membre expérimenté

    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    897
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2004
    Messages : 897
    Points : 1 561
    Points
    1 561
    Par défaut
    Effectivement je viens de voir
    Tu fais

    Tu ne peux pas car avec un TADOCommand tu as la propriété Execute car TADOCommand ne renvoit pas d'ensemble de résultats.
    Pensez à utiliser les tags dans le titre.
    Avant de poser une question reportez-vous à la FAQ Delphi
    Respectez les règles du forum.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2002
    Messages : 89
    Points : 64
    Points
    64
    Par défaut
    Je ne comprends pas...
    Moi ça bug à l'exécution sur la 1ère ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ADOCommand := TADOCOmmand.Create(nil);
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Connection := TADOConnection.Create(nil);
    ça passe chez toi ?
    Delphi 7 Pro, Visual Basic, Borland C++, WinXP, Win7

  6. #6
    Membre expérimenté

    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    897
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2004
    Messages : 897
    Points : 1 561
    Points
    1 561
    Par défaut
    tu as CoInitialize n'a pas été appelé

    Donc ajoute


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.Initialize;
    dans le projet source
    Pensez à utiliser les tags dans le titre.
    Avant de poser une question reportez-vous à la FAQ Delphi
    Respectez les règles du forum.

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2002
    Messages : 89
    Points : 64
    Points
    64
    Par défaut
    Merci beaucoup, c'était ça en effet...

    Delphi 7 Pro, Visual Basic, Borland C++, WinXP, Win7

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

Discussions similaires

  1. [Reflexivite]création dynamique d'objet et Héritage
    Par norkius dans le forum API standards et tierces
    Réponses: 5
    Dernier message: 26/10/2004, 11h37
  2. [D7] Création dynamique de Form
    Par jer64 dans le forum Composants VCL
    Réponses: 3
    Dernier message: 03/08/2003, 12h20
  3. [Rave Report] problème de création dynamique
    Par Nivux dans le forum Rave
    Réponses: 2
    Dernier message: 24/05/2003, 00h07
  4. TWebBrowser et création dynamique
    Par BakaOnigiri dans le forum Web & réseau
    Réponses: 2
    Dernier message: 01/09/2002, 10h53
  5. Création dynamique de TImages
    Par Dric dans le forum C++Builder
    Réponses: 10
    Dernier message: 08/07/2002, 12h36

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