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

 Delphi Discussion :

Filtre dans une table affiché dans un DBGRID


Sujet :

Delphi

  1. #1
    Membre régulier
    Homme Profil pro
    Analyste d'exploitation
    Inscrit en
    Décembre 2014
    Messages
    97
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Algérie

    Informations professionnelles :
    Activité : Analyste d'exploitation
    Secteur : Service public

    Informations forums :
    Inscription : Décembre 2014
    Messages : 97
    Points : 72
    Points
    72
    Par défaut Filtre dans une table affiché dans un DBGRID
    salam,


    j'ai une application avec delphi 7, pour la recherche d'un élément dans une table j'ai fait un filtre sur le nom
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
       Filtre := 'Nom =''' + FORM3.Edit2.Text + '*'''; {* Constrcuction du Filtre avec le texte saisi dans
    le resultat du filtre est affiché dans un DBGRID , le but est de récupérer l’enregistrement recherché dans des EDITS avec un clic sur cet enregistrement dans DBGRID , malheureusement l’enregistrement récupéré est toujours le premier dans la table . Veuillez nous aidez SVP et merci d'avance.

  2. #2
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2008
    Messages
    162
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Ukraine

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2008
    Messages : 162
    Points : 163
    Points
    163
    Par défaut
    Bonjour,
    Il est normal que tu obtienne seulement le premier résultat dans les edits.
    Pour obtenir les autres, il faudrait mettre un Table1.Next ; si je ne m'abuse.

  3. #3
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 042
    Points : 40 952
    Points
    40 952
    Billets dans le blog
    62
    Par défaut
    Bonjour,

    Comme je suis plutôt anti-filtre je propose en premier la solution utilisant une query :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM TABLE WHERE NOM=:N
    à remarquer que j'utilise également un paramètre
    on utilisera alors la query de la manière suivante
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Query.Active:=False;
    Query.ParamByName('N').asString:=form3.edit2.text;
    Query.Active:=True
    Cependant, comme je présume que la table est une table paradox, le filtre peut être plus rapide, encore faut-il l'activer et le rafraichir au besoin
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Table.Filtered:=False;
    Table.Filter:=Format('Nom= %s',[quotedStr(Form3.edit2.text)]);
    Table.Filtered:=True;
    dans les 2 cas, pour éviter un clignotement désagréable on en profite généralement pour encadrer le code par un DisableControls,EnableControls.

    Pour ce qui est de la suite de la question
    le but est de récupérer l’enregistrement recherché dans des EDITS avec un clic sur cet enregistrement dans DBGRID
    je n'ai malheureusement pas bien compris si les DBEdits sont lié au même datasource que la DBGrid cela ne devrait poser aucun soucis, si les DBEdits sont liés à un autre Datasource et donc une autre TTable il y a des possibilités de synchroniser les 2 tables de plusieurs manières :
    de GotoCurrent(<TTableFiltrée>)
    à toutes les méthodes permettant de se positionner sur le bon enregistrement (toujours BDE) FindKey,GotoKey etc...

    P.S. prenez soin d'indiquer de quel SGBD il s'agit, de quels composants d'accès aux données vous utilisez et d'une manière générale soyez plus explicite (rien ne nous indique si DBGrid fait partie de de la même forme que Form3.Edit2.Text (par pitié mettez des noms explicites) et que les "EDITS" qui à mon avis posent problème parce que justement ce sont des EDITS et non des DBEdits
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  4. #4
    Membre régulier
    Homme Profil pro
    Analyste d'exploitation
    Inscrit en
    Décembre 2014
    Messages
    97
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Algérie

    Informations professionnelles :
    Activité : Analyste d'exploitation
    Secteur : Service public

    Informations forums :
    Inscription : Décembre 2014
    Messages : 97
    Points : 72
    Points
    72
    Par défaut
    Merci beaucoup SergioMaster de ces détails et patience ,

    concernant ma question :
    le but est de récupérer l’enregistrement recherché dans des EDITS avec un clic sur cet enregistrement dans DBGRID
    c a d dans l’événement OncelleClick du DBGRID j'ai mis le code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    form1.edit1.text:=form3.Table1.FieldByName('code').AsString;
    form1.edit2.text:=form3.Table1.FieldByName('nom').AsString;
    form1.edit3.text:=form3.Table1.FieldByName('prenom').AsString;
    l'enregistrement récupéré dans form1.edit1.text - form1.edit2.text - form1.edit3.text c'est pas celui du filtre(mais c'est le premier enregistrement de la table du filtre).

    Merci et meilleur salutations.

  5. #5
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 042
    Points : 40 952
    Points
    40 952
    Billets dans le blog
    62
    Par défaut
    Re,

    je me permets de dire que votre programme est loin d'être clair !
    form3.table1 est-elle bien la table filtrée ?
    plutôt que l’événement OnCellClick essayez le OnDblClick de la DBGrid
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  6. #6
    Membre régulier
    Homme Profil pro
    Analyste d'exploitation
    Inscrit en
    Décembre 2014
    Messages
    97
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Algérie

    Informations professionnelles :
    Activité : Analyste d'exploitation
    Secteur : Service public

    Informations forums :
    Inscription : Décembre 2014
    Messages : 97
    Points : 72
    Points
    72
    Par défaut
    Re bonjour

    veuillez nous permettez la présentation du programme :

    au lancement :


    Nom : form pr.GIF
Affichages : 2752
Taille : 69,1 Ko

    lorsque je veut saisir le credit d'un client , je doit parcourir la liste des clients a travers le boutton Parcourir liste client : je cherche avec le nom :


    Nom : filtre.GIF
Affichages : 2965
Taille : 27,8 Ko

    alors je clique sur le client que je recherche pour rammener au forme principale :



    Merci d'avance.
    Images attachées Images attachées  

Discussions similaires

  1. afficher une table sql dans une table control
    Par coucoulido dans le forum WinDev
    Réponses: 4
    Dernier message: 06/06/2011, 12h20
  2. Réponses: 6
    Dernier message: 13/11/2009, 16h06
  3. Réponses: 1
    Dernier message: 11/06/2008, 13h33
  4. Réponses: 3
    Dernier message: 20/12/2006, 17h59
  5. Réponses: 6
    Dernier message: 16/06/2006, 13h22

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