"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > 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 (=) ?

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 (=) ?

Publié le 2024-11-01
Parcourir:911

Why Does MySQL Require Double Backslashes to Escape a Backslash in LIKE Queries But Not in Equals (=) Queries?

Comprendre l'échappement de la barre oblique () de MySQL dans les requêtes

Il est courant 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.

L'opérateur égal (=)

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.

L'opérateur LIKE

Contrairement à l'opérateur égal, l'opérateur LIKE nécessite un 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 assurez-vous que la barre oblique inverse unique dans le terme de recherche est interprétée littéralement comme une barre oblique inverse.

Explication

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.

Modification du caractère d'échappement

MySQL vous permet de spécifier un caractère d'échappement différent. pour les modèles LIKE à l'aide de 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 '|';

In 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é.

Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3