Maison >base de données >tutoriel mysql >Comment les index de texte intégral peuvent-ils améliorer les performances des requêtes LIKE \'%string%\' dans InnoDB ?

Comment les index de texte intégral peuvent-ils améliorer les performances des requêtes LIKE \'%string%\' dans InnoDB ?

Susan Sarandon
Susan Sarandonoriginal
2024-10-25 04:48:02884parcourir

How Can Fulltext Indexes Enhance Performance for LIKE '%string%' Queries in InnoDB?

Amélioration des performances MySQL pour les requêtes LIKE '%string%' dans InnoDB

Contexte : Optimisation des requêtes qui utilisent le LIKE '%string%' la syntaxe peut être difficile, en particulier dans un environnement InnoDB. Pour résoudre ce problème, examinons les options disponibles et leurs limites.

Limitations de l'indexation de base :

Création d'un index standard, comme démontré avec l'exemple ALTER TABLE ADD INDEX idxSearch (mots-clés) ne résout pas le problème de performances pour les requêtes telles que LIKE '%whatever%'. En effet, les index InnoDB sont construits du début à la fin de la chaîne. Par conséquent, les recherches « flottantes », dans lesquelles la chaîne peut apparaître n'importe où dans le champ, ne peuvent pas exploiter ces index.

Présentation des index de texte intégral :

Pour des recherches de chaînes flexibles , les index de texte intégral entrent en jeu. Ils sont adaptés aux scénarios dans lesquels les termes de recherche peuvent apparaître n'importe où dans la colonne indexée. La prise en charge par InnoDB des index de texte intégral à partir de la version 5.6.4 permet de tirer parti de leurs avantages même avec les tables InnoDB.

Implémentation :

Pour implémenter un index de texte intégral, exécutez la requête suivante :

ALTER TABLE example ADD FULLTEXT INDEX (keywords)

Avantages des index de texte intégral :

  • Performances de recherche optimisées pour les requêtes flottantes telles que LIKE '%whatever%'
  • Amélioration efficacité et latence réduite pour de telles requêtes

Considérations supplémentaires :

  • Assurez-vous que le serveur MySQL exécute au moins la version 5.6.4 pour utiliser InnoDB index de texte intégral.
  • Surveillez les plans de requête pour confirmer que l'index de texte intégral est utilisé efficacement.
  • Envisagez d'optimiser la taille de la colonne de mots-clés si elle contient des données excessives ou inutiles.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn