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 :

Probleme filtre Interbase


Sujet :

Bases de données Delphi

  1. #1
    Membre à l'essai
    Inscrit en
    Février 2004
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Février 2004
    Messages : 11
    Points : 11
    Points
    11
    Par défaut Probleme filtre Interbase
    Coucou,
    j'envoie ce post car j'ai un petit probleme...je fais une requete SQL de type select sur interbase, mais lorsque je souhaite lui ajouter un filtre, il ne semble pas s'appliquer.
    je ne comprends pas :s
    il suffit bien de faire quelque chose du genre :

    bidule.filter := "machine = bidule";
    bidule.filtered:=true;

    non?
    j'avais deja fait du delphi avec BDD mais j'utilisais MySQL..et c'était il y a un petit moment.

    merci d'avance,
    Steph.

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Février 2003
    Messages
    64
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Février 2003
    Messages : 64
    Points : 54
    Points
    54
    Par défaut
    Bonsoir,

    je pense que les ensembles de données unidirectionnels ne supportent pas le filtrage.

    Tu pourrais peut-être utiliser une table ou paramétrer ta requète pour la filtrer.

    Emmanuel.

  3. #3
    Membre habitué Avatar de alexmorel
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    196
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : Suisse

    Informations forums :
    Inscription : Septembre 2003
    Messages : 196
    Points : 157
    Points
    157
    Par défaut oui
    Le plus simple c'est d'integre dans ta requete directement le tri

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Select ... from ... where machine = 'bidule';

  4. #4
    Membre à l'essai
    Inscrit en
    Février 2004
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Février 2004
    Messages : 21
    Points : 20
    Points
    20
    Par défaut
    Pour ma part je pense également qu'il est plus simple de filtrer directement dans le SQL.

    Essaye un truc dans ce style :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Datamodule2.IBDataSet1.Close;
         Datamodule2.IBDataSet1.SelectSQL[0]  := 'Select * From Table;
         Datamodule2.IBDataSet1.Open;
    IBDataset ou IBQuery

  5. #5
    Membre expert
    Avatar de Barbibulle
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    2 048
    Détails du profil
    Informations personnelles :
    Âge : 54
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 2 048
    Points : 3 342
    Points
    3 342
    Par défaut
    Si tu tiens vraiment à utiliser les filtres locaux pour éviter de relancer une requete, utilise plutot l'évènement OnFilterRecord, normalement celui ci fonctionne bien.

  6. #6
    Membre à l'essai
    Inscrit en
    Février 2004
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Février 2004
    Messages : 21
    Points : 20
    Points
    20
    Par défaut
    OnFilterRecord a tendance à ramer si la table à filtrer est trop volumineuse, mais ca se joue en milliers d'occurences.

  7. #7
    Membre expert
    Avatar de Barbibulle
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    2 048
    Détails du profil
    Informations personnelles :
    Âge : 54
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 2 048
    Points : 3 342
    Points
    3 342
    Par défaut
    Oui c'est l'inconvéniant des filtres locaux, on transfert tous les enregistrements sur le poste client même ceux qui ne correspondent pas au filtre. Enfin quand on dit tous, ca ne veux pas dire toute la table, à moins de faire un fetchAll cad un IBDataSet.last. Dans ce cas oui toute la table est remontée, ce qui évidemment peux poser de gros problemes de performance si la table est grosse et si le programme tourne en mode client/serveur.

    C'est pourquoi dans ces cas là il est en effet préférable d'utiliser des requetes paramétrées ou à défaut une requete dynamique (moins performante qu'une requete parametrées.)

    Mais dans certains cas, le filtre sera plus performant. Par exemple si la table est petite et dans le cache mémoire lors d'un premier select. Faire une requete dynamique obligerai à réinterroger le serveur alors qu'un filtrage ne travaillerai qu en mémoire locale et donc serait plus performante.

    Donc ce choix se fait non pas dans l'absolue mais en connaissance de cause et suivant le contexte.

  8. #8
    Membre régulier
    Profil pro
    Architecte logiciel
    Inscrit en
    Octobre 2002
    Messages
    64
    Détails du profil
    Informations personnelles :
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Architecte logiciel

    Informations forums :
    Inscription : Octobre 2002
    Messages : 64
    Points : 88
    Points
    88
    Par défaut
    slut,

    si le champ Machine est de type chaine de caractere.

    ce code ne marchera pas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    bidule.filter := "machine = bidule";
    essaie ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    bidule.filter := "machine = 'bidule'"; 
    bidule.filtered:=true;
    A+.

Discussions similaires

  1. Probleme Firebird / Interbase 7
    Par ghor_bey dans le forum Firebird
    Réponses: 4
    Dernier message: 17/04/2008, 10h12
  2. probleme filtre access
    Par proleme dans le forum Access
    Réponses: 5
    Dernier message: 29/12/2007, 11h48
  3. [Excel] Probleme filtre élaboré
    Par mick_ban dans le forum Excel
    Réponses: 3
    Dernier message: 08/03/2007, 05h15
  4. Probleme Filtre web.xml
    Par Kiroukool dans le forum Servlets/JSP
    Réponses: 1
    Dernier message: 08/11/2006, 11h16
  5. probleme de interbase.interclient.Driver
    Par firebelge007 dans le forum Connexion aux bases de données
    Réponses: 10
    Dernier message: 21/01/2005, 17h38

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