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

Requêtes MySQL Discussion :

Optimisation de requete (REGEXP)


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12
    Par défaut Optimisation de requete (REGEXP)
    Bonjour,

    Je viens vers vous aujourd'hui car j'ai un problème avec une de mes requêtes SQL.

    Sur le site que je développe en ce moment j'ai des annonces qui contiennent une description, un titre et posté par un user (le cas d'école quoi). J'ai besoin de faire une recherche parmi ces informations, pour cela j'utilise ce type de requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM annonce_annuaire,user_annuaire WHERE user_annuaire.id_user = annonce_annuaire.id_user AND (titre REGEXP 'L(È|É|Ê|Ë|E|è|é|ê|ë|e)(ç|c)t(U|Ù|Ú|Û|Ü|ù|ú|û|ü|u)s p(È|É|Ê|Ë|E|è|é|ê|ë|e)d(È|É|Ê|Ë|E|è|é|ê|ë|e)' OR pseudo REGEXP '^.*L(È|É|Ê|Ë|E|è|é|ê|ë|e)(ç|c)t(U|Ù|Ú|Û|Ü|ù|ú|û|ü|u)s p(È|É|Ê|Ë|E|è|é|ê|ë|e)d(È|É|Ê|Ë|E|è|é|ê|ë|e).*$' OR description REGEXP '^.*L(È|É|Ê|Ë|E|è|é|ê|ë|e)(ç|c)t(U|Ù|Ú|Û|Ü|ù|ú|û|ü|u)s p(È|É|Ê|Ë|E|è|é|ê|ë|e)d(È|É|Ê|Ë|E|è|é|ê|ë|e).*$') ORDER BY date_annonce LIMIT 0,5;
    La requête me retourne exactement le résultat voulu, le problème étant le délais pour le retourner ...Si je n'applique pas la recherche sur le champ description le délais de réponse est très cours j'ai donc identifié le problème (le champ description peut contenir jusqu'à 10000 caractères).

    La question étant maintenant comment faire pour optimiser cela pour que le délais de recherche soit plus court ?

    Merci d'avance pour votre aide.

    Urda

  2. #2
    Membre Expert

    Profil pro
    Inscrit en
    Mars 2005
    Messages
    1 683
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 683
    Par défaut
    Vu le type de recherche, je pense qu'une indexation/recherche fulltext avec une bonne utilisation des collations serait plus adapté.

    Attention cependant, les fonctionnalités de recherche fulltext ne sont disponibles qu'en MyISAM.

    En général :
    http://blog.developpez.com/sqlpro/p9...ext-search-no/
    http://sqlpro.developpez.com/cours/s...er/collations/


    MySQL :
    http://dev.mysql.com/doc/refman/5.1/...xt-search.html
    http://dev.mysql.com/doc/refman/5.1/en/charset.html

Discussions similaires

  1. Optimisation de requete
    Par Scorff dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 11/07/2005, 09h59
  2. [sgbd]Optimisation des requetes Oracle/Perl
    Par linou dans le forum SGBD
    Réponses: 7
    Dernier message: 30/06/2005, 18h09
  3. Optimiser une Requetes SQL sous ASP
    Par NeHuS dans le forum ASP
    Réponses: 8
    Dernier message: 18/04/2005, 16h26
  4. Optimisation de requete
    Par cyril dans le forum SQL
    Réponses: 3
    Dernier message: 09/10/2003, 08h57
  5. Optimisation des requetes
    Par bifidus dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 06/10/2003, 11h29

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