MySQL : optimisation des recherches multi-chaînes dans des listes séparées par des virgules
La fonction find_in_set
de MySQL offre une approche simple pour rechercher des chaînes uniques dans des listes séparées par des virgules. Cependant, la recherche simultanée de plusieurs chaînes à l'aide de find_in_set
présente des limites importantes. Cet article explore ces limitations et présente une alternative supérieure utilisant les expressions régulières.
Les find_in_set
Lacunes
La principale limitation de find_in_set
est son incapacité à gérer plusieurs chaînes de recherche dans une seule requête. Cette restriction devient problématique lorsqu'il s'agit de grands ensembles de données ou de nombreux termes de recherche.
Une approche plus efficace : exploiter les expressions régulières
La suggestion d'enchaîner plusieurs find_in_set
appels à l'aide de l'opérateur OR est inefficace et devient vite lourde. Une solution beaucoup plus évolutive et efficace implique les capacités d'expression régulière de MySQL. La requête suivante le démontre :
<code class="language-sql">WHERE CONCAT(",", `setcolumn`, ",") REGEXP ",(val1|val2|val3),"</code>
Ici, setcolumn
fait référence à la colonne contenant votre liste séparée par des virgules, et val1
, val2
et val3
sont les chaînes que vous recherchez. L'opérateur REGEXP
vérifie si la chaîne concaténée (y compris les virgules de début et de fin) correspond au modèle d'expression régulière. Ce modèle recherche l'une des valeurs spécifiées, séparées par des virgules.
Avantages de la méthode Regexp
L'approche des expressions régulières offre plusieurs avantages clés :
find_in_set
opérations, en particulier avec un nombre croissant de termes de recherche.Cette solution basée sur les expressions rationnelles fournit une méthode plus robuste et efficace pour les recherches multi-chaînes dans des listes séparées par des virgules dans MySQL.
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!