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

Oracle Discussion :

Problème dans la recherche phonétique


Sujet :

Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Avril 2009
    Messages
    20
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 20
    Par défaut Problème dans la recherche phonétique
    Bonjour ;
    Mes amis j’ai crié une table qui s’appelle « identification » comporte les champs : numéro, nom, prénom, né le, adresse,…..
    Et je veux lancer une recherche phonétique en utilisant « Soundex » à condition que le résultat sera affiché dans un autre forms qui s’appel « rechercher ». J’ai tenté de mettre ce programme mais ça ne marche pas et le résultat final affiche tous les enregistrements.
    SVP donnez-moi votre aide pour trouver la solution et je vous notez que je suis débutant.
    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    declare
    	bs varchar2(200);
    	b varchar2(30);
    	I varchar2(30);
    	nom varchar2(30);
               prenom varchar2(30);
    begin
    	if: identification .nom is null then
    		message ('le champs nom est vide');
    		Raise Form_Trigger_Failure;
    	end if;
    		if: identification .Ne_LE is null then
    		message ('le champ Ne le est vide');
    		Raise Form_Trigger_Failure;
    	end if;
    if:system.record_status='INSERT' then
    bs:=' numéro='||' identification. numéro ';
    Set_block_property('rechercher',default_where,re);
    go_block('rechercher');
    execute_query;
    b:=get_block_property ('rechercher',Query_hits);
    	I :='(upper(prenom) like ''%'||prenom||'%'' and upper(nom) like ''%'||nom||'%'') or 
    (soundex(prenom)=soundex('''||prenom||''') and soundex(nom)=soundex('''||nom||''')) or 
    (upper(prenom) like ''%'||nom||'%'' and upper(nom) like ''%'||prenom||'%'') or 
    (soundex(prenom)=soundex('''||nom||''') and soundex(nom)=soundex('''||prenom||'''))';
    end if;
    if n='1'then
    	go_block(' identification');
    commit_form;
    next_record;
    previous_record;
    else
    	bs:='(Ne_LE='''||to_char (:identification.Ne_LE, 'DD-MON-YYYY')||''' and nom = '''||: identification.nom||''')';
    	bs:=bs||' or (Ne_LE= '''||to_char (:identification.Ne_LE-1,'DD-MON-YYYY')||'''and nom = '''||: identification.nom||''')';
    	bs:=bs||' or (Ne_LE= '''||to_char (:identification.Ne_LE+1,'DD-MON-YYYY')||'''and nom = '''||: identification.nom||''')';
    	set_block_property('rechercher',default_where,re);
    	execute_query;
    b:=get_block_property('rechercher',query_hits);
    if to_number (n)=0 then
    		go_block(' identification');
    		commit_form;
    		next_record;
    		previous_record;
    end if;
    end if;
    end;

  2. #2
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    Le code fourni est faux.

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set_block_property('rechercher',default_where,re);
    "re" n'est défini nulle part

    Pour exécuter une recherche avec une condition particulière, il faut bien utiliser
    Set_block_property('rechercher',default_where,XXXX), avec XXXX la chaine de la condition where à appliquer, et ensuite faire un execute query

    S'il y a un écart avec le résultat souhaité, il suffit d'afficher la condition where exécutée dans un champ et de vérifier cette condition en sql

  3. #3
    Membre averti
    Inscrit en
    Avril 2009
    Messages
    20
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 20
    Par défaut
    Pardon j’ai commis une erreur, lors de retaper le code

    le code exact c’est
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set_block_property('rechercher',default_where,bs);

Discussions similaires

  1. Réponses: 2
    Dernier message: 16/07/2014, 19h17
  2. [AC-2007] problème dans code recherche
    Par damito dans le forum IHM
    Réponses: 1
    Dernier message: 30/09/2010, 13h19
  3. [eZ Publish] Problème dans le module de recherche
    Par tamiii dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 3
    Dernier message: 09/04/2008, 20h13
  4. Problème dans un exercice(recherche)
    Par sassa4 dans le forum Excel
    Réponses: 2
    Dernier message: 22/12/2007, 16h43
  5. Problème de casse dans une recherche
    Par lipao17 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 06/07/2005, 10h55

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