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