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 :

Fonction renvoyant un TAdoQuery


Sujet :

Bases de données Delphi

  1. #1
    Futur Membre du Club
    Inscrit en
    Octobre 2004
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 15
    Points : 8
    Points
    8
    Par défaut Fonction renvoyant un TAdoQuery
    Bonjour,

    Je souhaiterais utiliser une fonction gérant les sélections de données sur une base ACCESS. Cette fonction renvoie comme résultat un TAdoQuery :

    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
     
    function RequeteSelection(lrequete : string):TAdoQuery;
    Var 
        lAdoQuery : TAdoQuery;
     
    begin
      lAdoQuery := TAdoQuery.Create(nil);
     
      Try
        lAdoQuery.Connection := DataModule1.adoconnection1;
        lAdoQuery.SQL.text := lrequete;
     
        lAdoQuery.Active := true;
        result := lAdoQuery;
     
      Finally
        lAdoQuery.Free;
      end;
    end;
    Mais comment récupérer ensuite ce résultat lorsque j'utilise cette fonction ? Le code suivant ne fonctionne pas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Var tempAdoQuery : TAdoQuery;
    (...)
    tempAdoQuery := RequeteSelection('SELECT * FROM Clients');
    Olivier

  2. #2
    Membre averti
    Profil pro
    xxxxxxxxxxx
    Inscrit en
    Juin 2004
    Messages
    308
    Détails du profil
    Informations personnelles :
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : xxxxxxxxxxx

    Informations forums :
    Inscription : Juin 2004
    Messages : 308
    Points : 407
    Points
    407
    Par défaut
    C'est à l'appelant de détruire l'objet après utilisation !
    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
    function RequeteSelection(lrequete : string):TAdoQuery;
    Var 
        lAdoQuery : TAdoQuery;
     
    begin
      lAdoQuery := TAdoQuery.Create(nil);
     
      Try
        lAdoQuery.Connection := DataModule1.adoconnection1;
        lAdoQuery.SQL.text := lrequete;
     
        lAdoQuery.Active := true;
        result := lAdoQuery;
     
      Finally
    //    lAdoQuery.Free;
      end;
    end;

  3. #3
    Futur Membre du Club
    Inscrit en
    Octobre 2004
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 15
    Points : 8
    Points
    8
    Par défaut
    J'avais aussi essayé sans "lAdoQuery.Free" mais ça ne marche pas mieux.

    Olivier

  4. #4
    Membre averti
    Profil pro
    xxxxxxxxxxx
    Inscrit en
    Juin 2004
    Messages
    308
    Détails du profil
    Informations personnelles :
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : xxxxxxxxxxx

    Informations forums :
    Inscription : Juin 2004
    Messages : 308
    Points : 407
    Points
    407
    Par défaut
    ben pourtant ça devrait ; Réessaye !

  5. #5
    Futur Membre du Club
    Inscrit en
    Octobre 2004
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 15
    Points : 8
    Points
    8
    Par défaut
    L'affectation "tempAdoQuery := RequeteSelection('SELECT * FROM Clients');" se fait sans erreur, mais ça plante lorsque j'essaye de faire "tempAdoQuery.First" ou "tempAdoQuery.Recordcount" par exemple.

    Olivier

  6. #6
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    essaie

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    tempAdoQuery.assign(RequeteSelection('SELECT * FROM Clients'));
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  7. #7
    Membre averti
    Profil pro
    xxxxxxxxxxx
    Inscrit en
    Juin 2004
    Messages
    308
    Détails du profil
    Informations personnelles :
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : xxxxxxxxxxx

    Informations forums :
    Inscription : Juin 2004
    Messages : 308
    Points : 407
    Points
    407
    Par défaut
    L'affectation "tempAdoQuery := RequeteSelection('SELECT * FROM Clients');" se fait sans erreur
    C'est donc que la requête s'ouvre.
    ça plante lorsque j'essaye de faire "tempAdoQuery.First" ou "tempAdoQuery.Recordcount"
    Message

  8. #8
    Futur Membre du Club
    Inscrit en
    Octobre 2004
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 15
    Points : 8
    Points
    8
    Par défaut
    "tempAdoQuery.First" provoque l'erreur "Violation d'accès à l'adresse 004a30C4 dans le module 'Projet.exe'. Lecture de l'adresse 8BD88BD7.".

    "tempAdoQuery.assign..." provoque l'erreur "Le projet projet.exe a provoqué une classe d'exception EAccessViolation avec le message 'Violation d'accès à l'adresse 004B58CC dans le module 'Projet.exe'. Lecture de l'adresse 8BD88B5B. Processus stoppé.".

    Une idée ?

  9. #9
    Membre averti Avatar de Bejaia-In
    Inscrit en
    Avril 2006
    Messages
    365
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 365
    Points : 392
    Points
    392
    Par défaut
    fonction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    function RequeteSelection(lrequete : string):TAdoQuery;
    begin
     result:=TAdoQuery.Create(nil);
     with result do begin
      try
       Connection := DataModule1.adoconnection1; 
       SQL.text := lrequete;
      except
       result.Free;
       raise
      end;
     end;
    end;
    utilisation :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     with RequeteSelection('SELECT * FROM clients') do
      Open;
    ....................................................................
    Aidez-vous... Dieu vous aideras et nous aussi..
    ....................................................................

  10. #10
    Futur Membre du Club
    Inscrit en
    Octobre 2004
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 15
    Points : 8
    Points
    8
    Par défaut
    Merci Bejaia-In.

    Mais utiliser "with RequeteSelection('SELECT * FROM clients') do" puis "First", "Next",... ne revient-il pas à exécuter x fois la même requête à chaque fois ?

    Anddi

  11. #11
    Futur Membre du Club
    Inscrit en
    Octobre 2004
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 15
    Points : 8
    Points
    8
    Par défaut Est-ce une bonne idée ?
    Plutôt que d'utiliser la fonction "function RequeteSelection(lrequete : string):TAdoQuery", je pensais utiliser une procédure avec une variable de type TAdoQuery (plutôt qu'un 'result'):

    Procedure RequeteSelection(lrequete : string; var wAdoQuery : TAdoquery);
    Il me suffirait ensuite d'utiliser une variable locale que je passerais en paramètre de ma fonction. Est-ce une bonne idée, notamment en terme d'utilisation de la mémoire ou autre ?

    Anddi

  12. #12
    Membre averti Avatar de Bejaia-In
    Inscrit en
    Avril 2006
    Messages
    365
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 365
    Points : 392
    Points
    392
    Par défaut
    Une requete est executé seulement losqu'on l'ouvre par "Open" ou par "Active:=True".
    L'avantage de la fonction dans notre cas est qu'elle est utilisée comme si c'était l'objet qu'elle retourne (TAdoQuery), donc simplicité et efficacité.
    ....................................................................
    Aidez-vous... Dieu vous aideras et nous aussi..
    ....................................................................

  13. #13
    Membre averti
    Profil pro
    xxxxxxxxxxx
    Inscrit en
    Juin 2004
    Messages
    308
    Détails du profil
    Informations personnelles :
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : xxxxxxxxxxx

    Informations forums :
    Inscription : Juin 2004
    Messages : 308
    Points : 407
    Points
    407
    Par défaut
    Les violations d'accès que tu obtiens sur un First ou Recordcount sont étranges, parce que le Open (='active:=true') est passé sans encombre.

    Je crains plutôt le paramétrage par défaut des ADODatasets (CursorLocation, Mode, ou autre) qui ferait que ces méthodes échoueraient.

    Tu ne rencontres pas les mêmes problèmes si tu utilises un ADOQuery créé en mode conception ?

Discussions similaires

  1. Fonction renvoyant une string
    Par salseropom dans le forum C
    Réponses: 8
    Dernier message: 04/05/2006, 11h44
  2. Fonction renvoyant char*
    Par Azharis dans le forum C++
    Réponses: 4
    Dernier message: 28/12/2005, 15h33
  3. Fonction renvoyant 0 ou 1
    Par NicoNGRI dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 26/10/2005, 10h56
  4. [VB6] [Syntaxe] Fonction renvoyant un tableau d'objets
    Par Troopers dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 18/10/2002, 15h33
  5. fonction renvoyant un tableau en argument
    Par Jones dans le forum Langage
    Réponses: 6
    Dernier message: 30/09/2002, 18h20

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