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 :

Pourquoi ma requête ne me retourne rien ?


Sujet :

Bases de données Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    pas grand chose
    Inscrit en
    Septembre 2018
    Messages
    131
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : pas grand chose
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Septembre 2018
    Messages : 131
    Par défaut Pourquoi ma requête ne me retourne rien ?
    Bonjour

    J ai la requête suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    for i := 0 to sl.Count - 1 do
      begin
     
        req := 'Select sum(bilan) as ZZ FROM tb_trades where date_close<' +
          sl[i] + ';';
        FDQuery1.SQL.Text := req;
        FDQuery1.Open();
     
        Bilan := FDQuery1.fieldbyname('ZZ').AsFloat;
        Chart1.Series[0].AddxY(i, Bilan);
      end;
    et le message d erreur '' n est pas une valeur en virgule flotante correcte.

    Si au lieu de sum(bilan) je teste avec un count(bilan), là tout fonctionne.
    quand je fais un select distinct de bilan, ici tout fonctionne encore, ce qui me laisse penser que les champs ne sont pas vides.

    J aimerai savoir comment tester le résultat, ce qui m éviterait cette erreur.

    J'imaginais que si le résultat était vide FDQuery1.RowsAffected retournerait 0 mais j ai toujours 1

    Je précise que je débute avec et que vos conseils et votre patience me seront bien précieux.

    Merci de votre aide

    Stéphane

  2. #2
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 739
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 739
    Billets dans le blog
    65
    Par défaut
    Bonjour,

    Tout d'abord, améliorer votre code me semble une bonne idée et pour ce utiliser une requête paramétrée
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    Select sum(bilan) as ZZ FROM tb_trades where date_close< :DI
    (où DI est le paramètre)
    En remarque, je ne sais pas quel est le SGBD, ni votre structure de table mais une requête avec un agrégat (SUM) nécessite souvent une clause GROUP BY

    l'avantage de la requête paramétrée est que celle-ci pourra être préparée

    Voilà ce que je propose ( comme pour votre précédent post j'écris le code "sans filet" cad directement sur le forum et donc sans test de syntaxe)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     FDQuery1.Close;
     FDQuery1.SQL.Text :='Select sum(bilan) as ZZ FROM tb_trades where date_close< :DI'; // requête paramètrée
     FDQuery1.Prepare; // permet d'améliorer le temps d'exécution par la suite du premier Open;
     for i := 0 to sl.Count - 1 do
      begin
          FDQuery1.ParamByName('DI').asInteger:=i;  // passage de la valeur du paramètre  
          FDQuery1.Open;
          If FDQuery1.FieldByName('ZZ').isNull 
                     then Chart1.Series[0].AddxY(i, 0)  // pas de date_ close<i                                            
                     else Chart1.Series[0].AddxY(i, FDQuery1.FieldByName('ZZ').asFloat);                                                           
          FDQuery1.Close; // là, j'ai un doute sur le comportement de Firedac donc je préfère fermer le dataset avant de changer la valeur du paramètre
       end;
    pour répondre aux autres questionnements
    et le message d erreur '' n est pas une valeur en virgule flottante correcte.
    en fait il faut lire NULL et pas ''
    Si au lieu de sum(bilan) je teste avec un count(bilan), là tout fonctionne.
    Count renvoi toujours une valeur ne serait-ce que 0
    quand je fais un select distinct de bilan, ici tout fonctionne encore, ce qui me laisse penser que les champs ne sont pas vides.
    Joker, cela dépend su SGBD
    J aimerai savoir comment tester le résultat, ce qui m éviterait cette erreur.
    j'ai déjà indiqué le test isnull mais on peut très bien intervenir directement au niveau de la requête presque tout les SGBD modernes connaissent COALESCE
    J'imaginais que si le résultat était vide FDQuery1.RowsAffected retournerait 0 mais j ai toujours 1
    RowsAffected opère plutôt avec des INSERT ou UPDATE c'est plutôt au RecordCount que vous pensez mais même ainsi la requête utilisée renvoie une ligne (avec la valeur NULL)

  3. #3
    Membre confirmé
    Homme Profil pro
    pas grand chose
    Inscrit en
    Septembre 2018
    Messages
    131
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : pas grand chose
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Septembre 2018
    Messages : 131
    Par défaut
    Bonjour

    Merci pour la réponse.


    J utilise sqlite.

    Etant en déplacement, je laisse le post ouvert jusqu'en fin de semaine car je ne peux tester dans l immédiat.

  4. #4
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 498
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 498
    Par défaut
    Salut

    tu peut faire aussi comme cela
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
      iCount  := pred(sl.Count);
      for i := 0 to iCount do
      begin
         FDQuery1.close;
         FDQuery1.SQL.clear;
         req := 'Select sum(coalesce(bilan,0)) as ZZ FROM tb_trades where date_close< %s ;' ;
         FDQuery1.SQL.add(format(req,[SL[I]])); 
         FDQuery1.Open();
         Bilan := FDQuery1.fieldbyname('ZZ').AsFloat;
        // bilan := FDQuery1.fields[0].AsFloat;
         Chart1.Series[0].AddxY(i, Bilan);
      end;

  5. #5
    Membre confirmé
    Homme Profil pro
    pas grand chose
    Inscrit en
    Septembre 2018
    Messages
    131
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : pas grand chose
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Septembre 2018
    Messages : 131
    Par défaut
    merci.

    coalesce correspond parfaitement à mes attentes.

Discussions similaires

  1. Requête cURLqui ne retourne rien
    Par Invité dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 5
    Dernier message: 27/03/2013, 22h45
  2. Réponses: 3
    Dernier message: 31/12/2010, 02h07
  3. [AJAX] Requête ajax ne retourne rien
    Par daisy22 dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 09/03/2009, 17h49
  4. Ma requête ne retourne rien!
    Par nounowa dans le forum JDBC
    Réponses: 6
    Dernier message: 12/07/2007, 17h17
  5. [MySQL] Requête qui ne retourne rien
    Par baleiney dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 28/06/2006, 19h29

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