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

PHP & Base de données Discussion :

Eviter les balises HTML dans une requête SQL [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Avatar de Freedolphin
    Homme Profil pro
    Webmaster
    Inscrit en
    Février 2006
    Messages
    291
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Février 2006
    Messages : 291
    Par défaut Eviter les balises HTML dans une requête SQL
    Bonjour à tous,

    J'ai un petit moteur de recherche interne qui va chercher le contenu texte d'une colonne, mais je souhaiterais qu'il ne tienne pas compte des balises HTML.
    Exemple : si je cherche le mot "target", il va faire ressortir les textes contenant un lien du type <a href="url" target="_blank">.
    Existe-t-il un moyen pour que la recherche ne s'effectue pas sur du texte contenu entre ces balises ?

    Merci d'avance pour vos pistes éclairées !

  2. #2
    Membre Expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 59
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Billets dans le blog
    8
    Par défaut
    Bonjour, ceci semble répondre à ta demande ?

    https://www.php.net/strip-tags

    edit :

    Ou plus exactement, cette fonction faite par un développeur (commentaire 40, si elle fonctionne, elle donne exactement ce que tu cherches).
    https://www.php.net/manual/fr/functi...ags.php#110280
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  3. #3
    Membre éclairé
    Avatar de Freedolphin
    Homme Profil pro
    Webmaster
    Inscrit en
    Février 2006
    Messages
    291
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Février 2006
    Messages : 291
    Par défaut
    Merci Dendrite mais strip_tags empêche l'affichage du code html. Ce que je cherche à éviter, c'est que la requête balaie le texte compris dans des balises.
    Je vais regarder plus attentivement la fonction envoyée, mais a priori, c'est la même chose, elle modifie l'affichage en supprimant les balises html.

  4. #4
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    Je ne vois pas ce qui t'empêche de :
    • Faire la recherche sur le texte sans balises (strip_tags)
    • Afficher le texte formaté (avec balises) concerné
    Dernière modification par Invité ; 10/09/2019 à 13h35.

  5. #5
    Invité
    Invité(e)
    Par défaut
    Bon,
    après moult tentatives infructueuses, il semble qu'on puisse s'en sortir directement dans la requête SQL :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT *
    FROM ma_table
    WHERE
    	le_texte_html LIKE '%le_mot%'
    AND
    	le_texte_html NOT REGEXP '.*<[^>]*le_mot[^>]*>.*'
    ;

    [EDIT] Argh...
    Ça ne va pas fonctionner comme voulu si le mot est à la fois dans et en dehors des balises.
    ex. <a href="le_mot.php">le_mot</a>.
    Dernière modification par Invité ; 10/09/2019 à 15h10.

  6. #6
    Membre éclairé
    Avatar de Freedolphin
    Homme Profil pro
    Webmaster
    Inscrit en
    Février 2006
    Messages
    291
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Février 2006
    Messages : 291
    Par défaut
    Faire la recherche sur le texte avec strip_tags, je ne vois pas comment.
    En revanche, je retiens ta proposition de code avec NOT REGEXP.

    EDIT :
    Argh également : en effet, ça ne trouve pas les mots répétés dans et hors balise.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Afficher les balises HTML dans une QTableView
    Par JOKER6 dans le forum Débuter
    Réponses: 4
    Dernier message: 04/11/2016, 12h24
  2. [Oracle] Ignorer les champs vides dans une requête sql
    Par roswina dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 26/05/2015, 09h29
  3. Utiliser les variables dans une requête sql
    Par LaPanic dans le forum Requêtes
    Réponses: 3
    Dernier message: 08/10/2012, 17h08
  4. Réponses: 3
    Dernier message: 04/01/2009, 21h21
  5. [SQL] compter les éléments distincts dans une requête
    Par redwire dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 08/10/2006, 17h44

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