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 de valeur dans une base Firebird 2.5 depuis Delphi


Sujet :

Bases de données Delphi

  1. #1
    Membre éprouvé
    Avatar de Andry
    Profil pro
    Informaticien
    Inscrit en
    Juillet 2002
    Messages
    1 164
    Détails du profil
    Informations personnelles :
    Localisation : Madagascar

    Informations professionnelles :
    Activité : Informaticien

    Informations forums :
    Inscription : Juillet 2002
    Messages : 1 164
    Points : 1 181
    Points
    1 181
    Par défaut Recherche de valeur dans une base Firebird 2.5 depuis Delphi
    Bonjour,
    J'ai une base composé de Code, Nom Prénom de client.
    Existe-t-il une fonction SQL qui permet d'avoir les clients correspondant à un critère donnée. Par exemple
    CODE |NOM | PRENOM
    000001|JEAN |PIERE
    000002|JEAN MICHEL |BERTHIER
    000003|JEAN |PAUL BERTHIER
    000004|JEANNE |D'ARC

    Si je cherche JEAN BERTHIER ou BERTHIER JEAN, je dois avoir
    000002
    000003
    Si je cherche JEAN, je dois avoir
    000001
    000002
    000003
    000004

    Avant que je vais m'amuser à créer des PS sous Firebird, je demande votre avis.
    Merci
    On progresse .....

  2. #2
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 031
    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 031
    Points : 40 930
    Points
    40 930
    Billets dans le blog
    62
    Par défaut
    Bonjour,

    C'est plus une question Firebird donc à poser sur ce forum que Delphi.

    Toutefois comme ce serait certainement moi qui y répondrai ...
    Le challenge est intéressant au niveau SQL, simple si la recherche est prénom + nom elle est plus complexe si les noms et prénoms peuvent être mêlés

    Si je cherche JEAN BERTHIER ou BERTHIER JEAN
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    AQuery.Active:=False; 
    AQuery.SQl.text:='SELECT CODE WHERE (PRENOM SIMILAR TO :Z1 AND NOM SIMILAR TO :Z2) OR (PRENOM SIMILAR TO :Z1 AND NOM SIMILAR TO :Z2)';
    AQuery.ParamByName('Z1').asString:='%'+zone1.text+'%';
    AQuery.ParamByName('Z2').asString:='%'+zone2.text+'%';
    AQuery.Active:=True;
    Si je cherche JEAN,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    AQuery.Active:=False; 
    AQuery.SQl.text:='SELECT CODE WHERE PRENOM STARTING WITH :Z1';
    AQuery.ParamByName('Z1').asString:=zone1.text;
    AQuery.Active:=True;
    cela dit, je trouve le jeu d'essai "biaisé"
    CODE |PRENOM | PRENOM
    000001|JEAN |PIERE
    000002|JEAN MICHEL |BERTHIER
    000003|JEAN |PAUL BERTHIER // soit le prénom est JEAN-PAUL soit ce n'est pas un mr BERTHIER le résultat à obtenir dans le cas 1 est-il correct ? Impliquant un SIMILAR TO
    000004|JEANNE |D'ARC
    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

  3. #3
    Membre confirmé Avatar de blonde
    Femme Profil pro
    Développeur Delphi
    Inscrit en
    Septembre 2003
    Messages
    278
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Delphi

    Informations forums :
    Inscription : Septembre 2003
    Messages : 278
    Points : 477
    Points
    477
    Par défaut
    Ça ne fera pas avancer la question, mais je viens de découvrir le "similar to". Merci.

  4. #4
    Membre éprouvé
    Avatar de Andry
    Profil pro
    Informaticien
    Inscrit en
    Juillet 2002
    Messages
    1 164
    Détails du profil
    Informations personnelles :
    Localisation : Madagascar

    Informations professionnelles :
    Activité : Informaticien

    Informations forums :
    Inscription : Juillet 2002
    Messages : 1 164
    Points : 1 181
    Points
    1 181
    Par défaut
    Bonjour et merci SergioMaster
    Je vais digérer tout ceci.
    D'autres questions viendront surement après.
    Andry
    On progresse .....

  5. #5
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 031
    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 031
    Points : 40 930
    Points
    40 930
    Billets dans le blog
    62
    Par défaut
    Autre possibilité de SQL


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT a.ID_UTILISATEUR, a.NOM, a.PRENOM
    FROM UTILISATEUR a
    WHERE a.PRENOM||a.NOM SIMILAR TO :Z'

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Zone1.Text:='JEAN';
    Zone2.Text:='BERTHIER';
    // Tous les utilisateurs dont le prenom contient JEAN et le nom contient BERTHIER
    Query1.ParamByName('Z').asString:='%'+Zone1.Text+'%'+Zone2.Text+'%';
    // Tous les utilisateurs dont le prenom commence par JEAN et le nom contient BERTHIER 
    Query1.ParamByName('Z').asString:=Zone1.Text+'%'+Zone2.Text+'%';
    // Tous les utilisateurs dont le prenom commence par JEAN et le nom se termine par  BERTHIER
    Query1.ParamByName('Z').asString:=Zone1.Text+'%'+Zone2.Text;
    pour finir une solution quand les zone1 et zone2 sont saisie en "désordre"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Query1.ParamByName('Z').asString:='%('+Zone1.Text+'|'+Zone2.Text+')%('+Zone1.Text+'|'+Zone2.Text+')%';
    et pour améliorer car je n'aime pas trop ces concaténations, l'utilisation de format :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Query1.ParamByName('Z').asString:=Format('%%(%0:s|%1:s)%%(%0:s|%1:s)%%',[Zone1.Text,Zone2.text);
    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

Discussions similaires

  1. [XL-2013] Recherche d'une valeur dans une base de données à 2 variables
    Par remdu62 dans le forum Excel
    Réponses: 3
    Dernier message: 23/04/2015, 10h59
  2. Rechercher une valeur dans une base de données
    Par encoremoi21258 dans le forum Requêtes
    Réponses: 3
    Dernier message: 09/02/2014, 22h29
  3. rechercher dans une base firebird
    Par zerros dans le forum SQL
    Réponses: 5
    Dernier message: 17/05/2010, 18h01
  4. [MySQL] Recherche d'une valeur dans une base
    Par lodan dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 13/12/2006, 20h01
  5. [9i] Recherche d'une valeur dans une base
    Par alpachico dans le forum Oracle
    Réponses: 1
    Dernier message: 16/06/2006, 09h53

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