Rechercher : dans
Par :

Requete SQL sous Delphi en Utilisant un Edit

Dernière réponse le 21 mai 2009 à 22:24:10 s_a_razak, le 10 aoû 2003 à 17:04:06 
 Signaler ce message aux modérateurs

Bonjour à tous,

afin de faire une sélection d'un ensemble d'enregistrements vérifiants la condition Cod_Fil=('le text d'un edit') d'une table Etudiant et les afficher sur un DBGRID, j'ai utilisé un Composant Query dont la propriété SQL contient le text suivant:
Select all
From Etudiant
Where Etudiant.Cod_fil=:Saisie

où (Saisie) est le nom du paramètre portant la valeur à saisir dans(Edit.text) (propriété params de Query)
le code de l'instruction Delphi est:
Query1.Parabyname('saisie').asinteger:=strtoint(edit1.text);­
Mais à l'exécution, le débogueur m'a notifier l'exception suivante:
Exception 'EDBEngineError' avec le message utilisation incorrecte du mot-clé Elément: From
N° de ligne 2: Processus stopé
Que faut-il faire pour filtrer une table en saisissant la valeur du champ sur lequel on veut faire la sélection ?

Meilleures réponses pour « Requete SQL sous Delphi en Utilisant un Edit » dans :
SQL - éviter les doublons dans un SELECT VoirProblème Comment éviter les doublons dans les résultats d'une requête SQL ? Solution Il suffit d'utiliser la clause DISTINCT entre SELECT et les champs. Exemple : SELECT distinct id,nom,prenom FROM matable Plus d'informations ...
Exécution de requêtes avec JDBC VoirExécution d'une requête SQL Pour exécuter une requête SQL, il s'agit dans un premier temps de créer un objet Statement, pouvant être obtenu à partir de l'objet Connection. Un objet ResultSet permettra de récupérer les données en provenance de...

1

ian, le 11 aoû 2003 à 10:06:38

Hello,
Je pense qu'il te manque le * dans ton select. Les messages d'erreurs des SGBD ne sont pas toujours treès pertinents : il te signale un pb au niveau du FROM car il ne s'attend pas à le treouver tout de suite après le ALL.
Essaye avec : SELECT * FROM etudiants...

A plus

Répondre à ian

2

tleboukaka, le 8 nov 2007 à 21:28:29

Salut

je crois être tout a fait capable de résoudre ce probleme de requete parametrée. car dans ma bdd Delphi 90% de mes requetes sont toutes de ce genre.
Le temps va vers la fin. demain si je me rappele je me connecterai et donnerai la réponse à ton pb

bon courage

Répondre à tleboukaka

3

tleboukaka, le 9 nov 2007 à 09:06:51

Slt

je suis là pour vouloir donner une solution à ton pb :
ce que je demande est que tu me détaille la structure de chaque table qui constitue la requete (du moins les champs importants et leur type : Numerique, Alphabetique ou AlphaNumerique)

Répondre à tleboukaka

4

tleboukaka, le 9 nov 2007 à 09:19:50

J'attends tjrs

Répondre à tleboukaka

5

ali, le 4 fév 2008 à 09:48:50

Comment utiliser une requete au delphi mais le parametre de cette requete est un champ d'une table

Répondre à ali

6

phil_232, le 4 fév 2008 à 10:16:06

SELECT * FROM MyTable1 WHERE MySearchID IN (SELECT MySearchID FROM Table2)

Répondre à phil_232

7

ali, le 5 fév 2008 à 09:32:43
  • +1

Comment crée une requete parametré mais le parametre prend les noms de colonnes d'une autre table

Répondre à ali

8

Vieux Mukal, le 20 fév 2008 à 16:23:07
  • +1

J'ai un serieux problème surtout lorsqu'il faut utiliser les requete parametré, car ça génère toujours un message d'erreur selon lequel le param n'est pas reconnus.
Pouvez me donner un bon code pour y arriver.

Cordialement
Vieux Mukal

Répondre à Vieux Mukal

9

phil_232, le 21 fév 2008 à 14:18:52

Peux-tu nous donner le message d'erreur ?

Répondre à phil_232

10

tleboukaka, le 21 fév 2008 à 20:37:22

Salut

voici comment tu dois proceder :

c'était pourtant important de bien definir ton architecture, pour nous permettre de bien résoudre ton problème. je part de l'idée que codFiliere est un champs de la table Etudiant. je suppose que les champs de la table Etudiant sont : num etudiant, nom etudiant, code filiere, etc
sur ton form :
place un composant TDBlookUpComboBox, et selectionne le en cliquant dessus
dans inspecteur d'objet, applique ces proprietés :
NAME : dlcCodFiliere
LIST SOURCE : dataSourceEtudiant (le dataSource de la table Etudiant)
LIST FIELD : cod_Filiere (ou Nom filiere)
KEY FIELD : cod_Filiere
ensuite
tu place un tButton (exemple bouton OK / EXECUTER)
en bas tu place un TDBGrid (c'est là que va s'afficher le contenu de ta requete une fois que tu clique sur le bouton OK)

tu va paramettrer maintenant ton Query
Selectionne le depuis l'Arbre d'Objet, clique sur son signe +, clique droit sur Param. clik encore sur AJOUTER ARTICLE du menu contextuel
dans inspecteur objet : renseigne DATA TYPE avec ftString
renseigne aussi NAME en tapant ParamCodFiliere
tu peu sauvegarder...

ensuite
evenement On Clic de ton bouton, tu ecrit le sql de ta requete du genre :

...
begin
query1.SQL.Clear;
query1.SQL.Add ('SELECT TblEleve.elvNum, tbleleve.ElvNom, tblEleve.CodFiliere, ... ');
query1.SQL.Add ('FROM ...');
query1.SQL.Add ('INNER JOIN .... ON... ');
query1.SQL.Add ('WHERE (codFiliere = :ParamCodFiliere) ');
query1.SQL.Add ('ORDER BY ... ');
query1.ParamByName ('ParamCodFiliere').AsString:=dlcCodFiliere.Text;
query1.Open;
end;
...

enfin, tu dois parametrer ton TDBGrid
selectionne ton dbGrid
dans Inspecteur Objet, renseigne son dataSource. il correspond au datasource de la requete query1

voilà, celà DEVAIT marcher sans problème
90% de mes requetes sont parametrées, voir même des parametres sur 3 niveaux et ça marche comme cela

bon courage

Eric

Répondre à tleboukaka

12

 imeneimene, le 21 mai 2009 à 22:24:10

Bonjour ,
mais ou trouver l'Arbre d'Objet du Query;

Répondre à imeneimene

11

tleboukaka, le 22 fév 2008 à 12:57:16

Salut

j'ai oublié un détail :
Sélectionne ton composant Query1
dans Inspecteur Objet, renseigne la valeur DATABASENAME
Proprieté ACTIVE = False
sur la ligne SQL dans Inspecteur Objet tjrs, clique sur le bouton ...
colle l'instruction de ta requete comme suit :

SELECT TblEleve.elvNum, tbleleve.ElvNom, tblEleve.CodFiliere, ...
FROM ...
INNER JOIN .... ON...
WHERE (codFiliere = :ParamCodFiliere)
ORDER BY ...

REMARQUE que ça commence par SELECT et termine par Order BY

ensuite clique sur OK pour fermer cette petite fenetre.

Si ça marche ça fairait plaisir que vous le fassiez savoir

ERIC

Répondre à tleboukaka