Précédent   Forum des professionnels en informatique > PHP > Langage > Regex
Regex Forum d'entraide sur les expressions rationnelles PHP. Avant de poster -> FAQ regex, Cours de regex et Sources de regex
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 04/06/2011, 23h08   #1
Invité de passage
 
Inscription : mars 2007
Messages : 12
Détails du profil
Informations forums :
Inscription : mars 2007
Messages : 12
Points : 3
Points : 3
Par défaut Traduction d'un champ de recherche avec opérateurs booléens en "français" vers du SQL

Bonjour,

Je me permets de vous soumettre une colle sur laquelle je me casse les dents...

J'ai un champ de recherche de formulaire qui présente des structures de la forme :

"mot clé 1" OU "mot clé 2" OU ("mc 3" ET "mc 4") SAUF "mc 5"

Donc une succession de mots-clés avec les opérateurs ET, OU, SAUF qui peuvent intervenir dans n'importe quel ordre, avec éventuellement des parenthèses.

Je cherche à traduire ce champ de recherche en langage SQL. Ce qui devrait donner pour l'exemple ci-dessus :

Code :
ma.table REGEXP '[[:<:]]mc 1[[:>:]]' OR ma.table REGEXP '[[:<:]]mc 2[[:>:]]' OR (ma.table REGEXP '[[:<:]]mc 3[[:>:]]' AND REGEXP '[[:<:]]mc 4[[:>:]]') AND ma.table NOT REGEXP '[[:<:]]mc 5[[:>:]]'
Précision du REGEXP '[[:<:]]blabla[[:>:]]' : je cherche le mot-clé exact, éventuellement noyé dans autre chose.

En recherche d'une idée miraculeuse (et surtout avec beaucoup d'essais plus au moins bien inspirés), je suis arrivé à un algo de la forme :

Code :
1
2
3
4
5
$res = preg_replace("#^\"([^\"]*)\"#","$champ REGEXP '[[:<:]]$1[[:>:]]' ",$data);
$res = preg_replace ("#^SAUF \"([^\"]*)\"#","$champ NOT REGEXP '[[:<:]]$1[[:>:]]' ",$res);
$res = preg_replace ("#[^^]SAUF \"([^\"]*)\"#"," AND $champ NOT REGEXP '[[:<:]]$1[[:>:]]' ",$res);
$res = preg_replace("#ET \"([^\"]*)\"#","AND $champ REGEXP '[[:<:]]$1[[:>:]]' ",$res);
$res = preg_replace("#OU \"([^\"]*)\"#","OR $champ REGEXP '[[:<:]]$1[[:>:]]' ",$res);
Problèmes : cela ne répond pas a priori à 100% des requêtes qui peuvent être formulées, et ne me semble pas très propre...

Je suis à cours d'inspiration sur les approches possibles, je suis donc preneur de tout conseil

Many thanks !
Voodu est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 18h43.


 
 
 
 
Partenaires

Hébergement Web