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 :

Recherche dans table paradox


Sujet :

Bases de données Delphi

  1. #1
    Membre confirmé

    Inscrit en
    Novembre 2002
    Messages
    744
    Détails du profil
    Informations forums :
    Inscription : Novembre 2002
    Messages : 744
    Points : 500
    Points
    500
    Par défaut Recherche dans table paradox
    bonjour a tous,

    je suis novice en base en base de données.
    je cherche a faire une recherche dans un champ alpha d'une base de donnée paradox

    j'arrive a faire la recherche :
    si le contenu de ma recherche est = au contenu du champ
    totato => totato
    si le contenu de ma recherche est au debut de mon champ
    to* => totato

    mais je voudrai aussi trouver un therme qui se trouverait dans le champ
    *ta* => totato

    Est ce possible si oui , comment faire et si possible un exemple serait le bien venu je suis sur les BD depuis hier !

    merci d'avance
    Bye et bon code...

    Ce n'est pas tant l'aide de nos amis qui nous aide , mais notre confiance dans cette aide .

  2. #2
    Membre expert
    Avatar de TicTacToe
    Inscrit en
    Septembre 2005
    Messages
    1 940
    Détails du profil
    Informations personnelles :
    Âge : 51

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 940
    Points : 3 575
    Points
    3 575
    Par défaut
    Salut,

    Oui bien sur il y a des solutions à ton problèmes.
    Mais d'abord, comment arrive-tu à tes 1ers résultats, via des requete SQL ou via des instructions type Table.SetRange, ou via la propriété Table.Filter ?

    Car la solution, c'est soit par requete SQL (et la je te donnerai pas le code car je suis pas dedans du tout), soit via l'évènement Table.OnFilterRecord.

    Tu peux dire via le parametre "Accept", si tu acceptes l'enregistrement courant de ta table ou non selon tes contraintes. En utilisant Pos(...) sur ton champs par exemple.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    procedure TForm1.Table1FilterRecord(DataSet: TDataSet;
      var Accept: Boolean);
    begin
         Accept := Pos( 'ta', Table1.FieldByName( 'TonChamp' ).AsString ) <> 0;
    end;
    bon courage
    Section Delphi
    La mine d'or: La FAQ, les Sources

    Un développement compliqué paraitra simple pour l'utilisateur, frustrant non ?
    Notre revanche ? l'inverse est aussi vrai ;-)

  3. #3
    Membre confirmé

    Inscrit en
    Novembre 2002
    Messages
    744
    Détails du profil
    Informations forums :
    Inscription : Novembre 2002
    Messages : 744
    Points : 500
    Points
    500
    Par défaut
    Salut TicTacToe et merci ,

    J'utilise un Ttable,Tsatasource et Bdgrid. Voila les deux routine que j'utilise , une pour la recherche et une pour un filtre.


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    procedure TMain.RechercheClick(Sender: TObject);
    var Option : TLocateOptions;
    begin
      if  RechSociete.Text='' then exit;
      Option := [loPartialKey];
      Table.Locate('Société',RechSociete,Option);
    end;
     
    procedure TMain.FiltreSocieteClick(Sender: TObject);
    var CoFiltre : string;
    begin
       Table.Filtered:=false;
        if Filtre.text='' then exit;
        CoFiltre := 'Société ='''+'' + Filtre.Text + '*''';
        Table.Filter := COFiltre;
        Table.Filtered := true;
    end;
    Pour la recherche j'avais pensé aussi mettre la table dans une boucle et controler avec un "ANSIPOS" l'enregistrement en question . Je pensais qu'une fonction existait ( pour optimisation) . Surtout que je peux aussi vouloir faire des combinaisons entre les colonnes.

    En fait c'est dans le filtrage que je suis embetté , je sais confectionner un filtre du genre " TA* " qui marche, mais pas un filtre du genre " *TA* " qui ne marche pas ( enfin si j'ai pas deconné!! ) ,

    Il est evident que la methode que tu m'as donné si dessus peut aussi faire l'affaire. Peut etre que cette methode est plus lente que la methode TTable.filtre. N'etant pas habitué aux bases de donnéex je ne sais pas si çà joue sur le temps de recherche ou de tri.

    Si d'autre info vous viennent à l'esprit...merci
    Bye et bon code...

    Ce n'est pas tant l'aide de nos amis qui nous aide , mais notre confiance dans cette aide .

  4. #4
    rsc
    rsc est déconnecté
    Membre éprouvé
    Avatar de rsc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juin 2004
    Messages
    711
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2004
    Messages : 711
    Points : 918
    Points
    918
    Par défaut
    Syntaxe SQL pour une recherche partielle sur un champ texte

    Roland

  5. #5
    Membre régulier
    Inscrit en
    Novembre 2006
    Messages
    107
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 107
    Points : 115
    Points
    115
    Par défaut
    Pour Effectué une recherche dans BDD il exist plusieurs méthode je vous explique les plus simple à utilisé
    1 er Méthode
    1-Recherche Directe:
    La recherche directe consiste à utilisé l'index Primaire par exemple
    je voudrais recherche un client par son code Client en utilisant la commande FindKey
    Programme
    Table1.FindKey([NUMCLIENT]);
    1-Recherche Sequentiel
    La recherche Sequentiel utilise l'index Secondaire par exemple
    je voudrais recherche un client par son Nom Client
    Programme
    Table1.FindNereast([NOMCLIENT]);

Discussions similaires

  1. [SQL] Recherche dans table le nombre d'enregistrement en horizontale
    Par Dsphinx dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 30/04/2007, 07h18
  2. Recherche dans table de BDD par rapport à deux champs
    Par kiops dans le forum Bases de données
    Réponses: 4
    Dernier message: 09/03/2007, 12h21
  3. Images JPEG dans table Paradox
    Par liazidf dans le forum Bases de données
    Réponses: 4
    Dernier message: 04/03/2007, 18h00
  4. Recherche dans table MYSQL
    Par cerede2000 dans le forum SQL Procédural
    Réponses: 5
    Dernier message: 18/01/2007, 13h31
  5. recherche dans table maitre detail
    Par pierrot67 dans le forum Bases de données
    Réponses: 3
    Dernier message: 27/03/2006, 13h00

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