Précédent   Forum des professionnels en informatique > Bases de données > Firebird > Connexion aux bases de données
Connexion aux bases de données Forum d'entraide sur la connectivité Firebird: composants, drivers, transactions, etc.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 08/09/2005, 18h21   #1
Membre régulier
 
Avatar de the watcher
 
Inscription : juillet 2003
Messages : 356
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 356
Points : 81
Points : 81
Envoyer un message via MSN à the watcher Envoyer un message via Yahoo à the watcher Envoyer un message via Skype™ à the watcher
Par défaut Verification de code pour IBQuery

Salut les amis,
Vérifiez s'il vous plaît ce code pour moi.

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
Procedure TForm2.ComboClasseSelect(Sender: TObject);
var
  DESIGN_CLASS  : String;
begin
{**** Recherche d'instruction sql pour le remplissage
      des frais d'inscription et de formation}
      //CurrencyEdit2.Text:= ;
      ComboClasse.Text:=DESIGN_CLASS;
      IBQuery1.Active:=True;
      IBQuery1.Close;
      IBQuery1.SQL.Clear;
      DESIGN_CLASS:=IBQuery1.ParamByName('DESIGN_CLASS').AsString  ;
      IBQuery1.SQL.ADD('SELECT FRFORMA FROM FRAIS WHERE DESIGN_CLASS = ''DESIGN_CLASS''');
      IBQuery1.SQL.ADD('VALUE (:DESIGN_CLASS)');
 
      IBQuery1.Params[0].AsString := DESIGN_CLASS;
      IBQuery1.ExecSQL;
      CurrencyEdit1.Text := IBQuery1.FieldByName('FRFORMA').AsString;
 
end;
Lorsque j'applique l'evenement onselect de mon ComboBox, une boîte de dialogue : Paramètres DESIGN_CLASS non trouvés s'affiche.
the watcher est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/09/2005, 19h40   #2
Expert Confirmé
 
Avatar de qi130
 
Homme Pierre
Ingénieur qualité méthodes
Inscription : mars 2003
Messages : 3 726
Détails du profil
Informations personnelles :
Nom : Homme Pierre
Âge : 51
Localisation : France

Informations professionnelles :
Activité : Ingénieur qualité méthodes
Secteur : Finance

Informations forums :
Inscription : mars 2003
Messages : 3 726
Points : 4 739
Points : 4 739


un petit rappel sur le SQL serait le bienvenu....(syntaxe de la commande SELECT)

Dans ton code:

que vaut DESIGN_CLASS (la variable) quand tu l'affectes à ComboClasse.Text ?

3 lignes + bas:

tu alimentes DESIGN_CLASS par un paramètre de IBQuery1 que tu viens juste de fermer (on ne sait pas si elle a été exécutée, ni avec quelle commande, ni le résultat de l'exec)

Bref, ça me parait confus....

Sais-tu bien ce que tu veux faire ?
__________________
"Il n'y a pas de bonnes réponses à une mauvaise question." (M. Godet)
-----------------------
Pensez à cloturer votre sujet - Aucune réponse aux sollicitations techniques par MP
Usus magister est optimus
qi130 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/09/2005, 19h41   #3
Membre expérimenté
 
Avatar de neilbgr
 
Inscription : août 2004
Messages : 584
Détails du profil
Informations forums :
Inscription : août 2004
Messages : 584
Points : 589
Points : 589
Citation:
Procedure TForm2.ComboClasseSelect(Sender: TObject);
var
DESIGN_CLASS : String;
begin
{**** Recherche d'instruction sql pour le remplissage
des frais d'inscription et de formation}
//CurrencyEdit2.Text:= ;
ComboClasse.Text:=DESIGN_CLASS; // <-- DESIGN_CLASS n'est pas initialisé !
IBQuery1.Active:=True; // <-- Inutile si y a un Close juste après
IBQuery1.Close;
IBQuery1.SQL.Clear; // <-- Tu viens d'effacer la requete.....
DESIGN_CLASS:=IBQuery1.ParamByName('DESIGN_CLASS').AsString ; // <-- ...donc y a rien dedans, pas meme le paramètre 'DESIGN_CLASS' !
IBQuery1.SQL.Add('SELECT FRFORMA FROM FRAIS WHERE DESIGN_CLASS = ''DESIGN_CLASS'''); // <-- plutot ecrire: [...]WHERE DESIGN_CLASS = ESIGN_CLASS');
IBQuery1.SQL.Add('VALUE (ESIGN_CLASS)'); // <-- Ce n'est pas du SQLvalable dans un SELECT

IBQuery1.Params[0].AsString := DESIGN_CLASS; // <-- là par contre le paramètre existe (si correction), donc ecrire: ParamByName('DESIGN_CLASS').AsString := DESIGN_CLASS;
IBQuery1.ExecSQL; >// <-- F1 sur ExecSQL.. c pas le bon, il faut faire Open;
CurrencyEdit1.Text := IBQuery1.FieldByName('FRFORMA').AsString;

end;
__________________
"Si vous voulez être l’esclave des banques et payer pour financer votre propre esclavage, alors laissez les banquiers créer la monnaie" - Josiah Stamp, 1920, Gouverneur de la Banque d’Angleterre
"Qui ne peut acheter ruine qui voudrait vendre" - Jacques Duboin.
"Nous n'héritons pas la terre de nos parents, nous l'empruntons à nos enfants." - Antoine de Saint Exupéry
neilbgr est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/09/2005, 20h32   #4
Membre régulier
 
Avatar de the watcher
 
Inscription : juillet 2003
Messages : 356
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 356
Points : 81
Points : 81
Envoyer un message via MSN à the watcher Envoyer un message via Yahoo à the watcher Envoyer un message via Skype™ à the watcher
Euhhh!!! En faite voila
c'est que c'est le contenu du combobox qui sera le critère d'affichage
c'est comme si je faisais un truc de ce genre:

Code :
'select champ1 from table1 where champ2 = 'xxxx''
le resultat sera affiché dans le TEdit1
mais ce resultat affiché dépendra du contenu du combobox

Vous voyez un peu ce que je veux faire les amis.
the watcher est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/09/2005, 20h47   #5
Membre expérimenté
 
Avatar de neilbgr
 
Inscription : août 2004
Messages : 584
Détails du profil
Informations forums :
Inscription : août 2004
Messages : 584
Points : 589
Points : 589
Dans l'inspecteur d'objet, IBQuery1.SQL doit contenir :
Code :
1
2
3
4
 
SELECT FRFORMA
FROM FRAIS
WHERE DESIGN_CLASS = :DESIGN_CLASS

Dans le code :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
 
Procedure TForm2.ComboClasseSelect(Sender: TObject);
begin
{**** Recherche d'instruction sql pour le remplissage
      des frais d'inscription et de formation}
  WITH IBQuery1 do
    begin
      Close;
      ParamByName('DESIGN_CLASS').AsString := ComboClasse.Text;
      Open;
      IF NOT Eof then
        CurrencyEdit1.text := FieldByName('FRFORMA').AsString
      else
        // Pas de resultat, ON fait coa ?
    end;
end;
Comprends-tu la démarche ?
__________________
"Si vous voulez être l’esclave des banques et payer pour financer votre propre esclavage, alors laissez les banquiers créer la monnaie" - Josiah Stamp, 1920, Gouverneur de la Banque d’Angleterre
"Qui ne peut acheter ruine qui voudrait vendre" - Jacques Duboin.
"Nous n'héritons pas la terre de nos parents, nous l'empruntons à nos enfants." - Antoine de Saint Exupéry
neilbgr est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/09/2005, 21h12   #6
Membre régulier
 
Avatar de the watcher
 
Inscription : juillet 2003
Messages : 356
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 356
Points : 81
Points : 81
Envoyer un message via MSN à the watcher Envoyer un message via Yahoo à the watcher Envoyer un message via Skype™ à the watcher
Tu n'vas pas m'croire:
Figure-toi que dans l'inspecteur d'objet, IBQuery1.SQL j'ai écrit ceci:

Code :
1
2
3
SELECT FRFORMA
FROM FRAIS 
WHERE DESIGN_CLASS =  'Gecom A'
alors ce 'Gecom A' n'est qu'un critère d'affichage pour une classe !!! C'est pas vrai.

Ok ça y est il tourne à merveille.

Grand merci.
the watcher est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 08h40.


 
 
 
 
Partenaires

Hébergement Web