Maison >développement back-end >tutoriel php >Pourquoi MySQL nécessite-t-il des doubles barres obliques inverses pour échapper une barre oblique inverse dans les requêtes LIKE mais pas dans les requêtes égales (=) ?
C'est une pratique courante dans MySQL d'échapper aux caractères spéciaux, y compris la barre oblique inverse () , dans les requêtes pour éviter les conflits d'interprétation. Cependant, une curieuse anomalie apparaît lorsque l'on compare le comportement de l'opérateur égal (=) et de l'opérateur LIKE en ce qui concerne la barre oblique inverse.
Dans le cas de l'opérateur égal, aucune barre oblique inverse supplémentaire n'est requise pour échapper à la barre oblique inverse dans le terme de recherche. Par exemple, la requête suivante récupère la ligne où la colonne de titre contient la valeur « test ».
SELECT * FROM `titles` WHERE title = 'test\';
L'analyseur MySQL interprète automatiquement la barre oblique inverse dans le terme de recherche comme un caractère littéral, d'où la récupération réussie.
Contrairement à l'opérateur égal, l'opérateur LIKE nécessite une barre oblique inverse supplémentaire pour échapper à la barre oblique inverse dans le terme de recherche. En effet, l'opérateur LIKE effectue une correspondance de modèle et la barre oblique inverse agit par défaut comme caractère d'échappement dans SQL. Ainsi, la requête suivante récupère la même ligne que la précédente :
SELECT * FROM `titles` WHERE title LIKE 'test\\';
Dans cette requête, les doubles barres obliques inverses garantissent que la barre oblique inverse unique dans le terme recherché est interprétée littéralement comme un caractère barre oblique inverse.
La raison derrière ce comportement est enracinée dans la façon dont MySQL traite les modèles LIKE. L'analyseur supprime initialement les barres obliques inverses du terme de recherche. Cependant, lorsque la correspondance de modèle est effectuée ultérieurement, les barres obliques inverses sont à nouveau supprimées. Cela laisse une seule barre oblique inverse à comparer au modèle. Pour garantir que la barre oblique inverse est traitée comme un caractère littéral, la barre oblique inverse supplémentaire est requise.
MySQL vous permet de spécifier un caractère d'échappement différent caractère pour les modèles LIKE utilisant la clause ESCAPE. Par exemple, la requête suivante utilise le caractère barre verticale (|) comme caractère d'échappement :
SELECT * FROM `titles` WHERE title LIKE 'test\' ESCAPE '|';
Dans cet exemple, la barre oblique inverse unique dans le terme de recherche est interprétée littéralement car elle est précédée du caractère d'échappement spécifié. .
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!