Énoncé du problème :
Compter le nombre de mots dans une base de données MySQL la colonne utilisant des expressions régulières est une tâche courante. Cependant, l'approche standard consistant à utiliser LENGTH(name) - LENGTH(REPLACE(name, ' ', '') 1 échoue lorsque plusieurs espaces séparent les mots. Cette question explore une solution alternative qui exploite la fonctionnalité Regex.Replace pour des résultats plus précis. résultats.
Solution :
La base de données MySQL propose la fonction REGEXP_REPLACE, qui peut être utilisée comme fonction définie par l'utilisateur. Cette fonction fournit le comportement Regex.Replace souhaité. Pour compter les mots avec cette approche, considérez la requête suivante :
SELECT LENGTH(REGEXP_REPLACE(name, '\s+', ' ')) - LENGTH(REGEXP_REPLACE(name, '\s+', '') +1 FROM table
Cette requête remplace plusieurs espaces par un seul espace, en comptant efficacement les espaces. comme délimiteurs de mots.
Considérations alternatives :
Pour des performances optimales, il est recommandé d'empêcher les doubles espaces de entrer dans la base de données. De plus, si le nombre de mots est consulté fréquemment, il peut être calculé une fois et stocké dans la base de données pour une récupération plus rapide.
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!