Maîtriser les recherches génériques insensibles à la casse dans MySQL
De nombreux développeurs sont confrontés au besoin d'effectuer des recherches insensibles à la casse. Les recherches standard MySQL LIKE
par caractères génériques sont, par défaut, sensibles à la casse. Cette limitation peut être problématique lors de la recherche de données susceptibles d'être stockées avec des majuscules variables.
Considérons cet exemple : une recherche de "orme" dans la colonne title
d'un tableau trees
:
<code class="language-sql">SELECT * FROM trees WHERE trees.title LIKE '%elm%';</code>
Cette requête récupère uniquement les lignes où « elm » est explicitement en minuscule. Des entrées comme "Elm" ou "ELM" seraient manquées.
Pour réaliser une recherche insensible à la casse, utilisez la fonction LOWER()
. Cette fonction convertit les chaînes en minuscules, permettant ainsi les correspondances quelle que soit la majuscule.
Voici comment effectuer une recherche insensible à la casse pour "elm" :
<code class="language-sql">SELECT * FROM trees WHERE LOWER(trees.title) LIKE '%elm%';</code>
Cette requête révisée renverra toutes les lignes contenant « orme » dans la colonne title
, qu'elles soient en majuscules, minuscules ou un mélange des deux.
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!