在 MySQL 的 NO_BACKSLASH_ESCAPES 模式中转义文字百分比和下划线字符
在 MySQL 中,NO_BACKSLASH_ESCAPES 模式禁用传统的反斜杠字符 () 作为转义LIKE 查询中的机制。此模式在尝试转义百分号 (%) 和下划线 (_) 字符时带来了挑战。
标准转义方法
转义百分号字符的标准方法LIKE 查询是在其前面加上反斜杠 ()。但是,在 NO_BACKSLASH_ESCAPES 模式下,此方法不起作用。
转义字符替代
要在不使用反斜杠的情况下转义文字字符,您可以使用以下命令指定替代转义字符ESCAPE 关键字。例如:
SELECT * FROM mytable WHERE mycol LIKE '5\% off' ESCAPE '\';
版本无关转义
要创建一个无论 NO_BACKSLASH_ESCAPES 模式设置如何都有效的查询,您可以使用不同的转义字符。例如,管道字符 (|) 可以定义为转义字符:
SELECT * FROM mytable WHERE mycol LIKE '5|% off' ESCAPE '|';
通过指定替代转义字符,即使在 NO_BACKSLASH_ESCAPES 模式下,您也可以有效地转义文字 % 和 _ 字符。这允许创建在不同 MySQL 配置中可靠工作的 LIKE 查询。
以上是如何在 MySQL 的 NO_BACKSLASH_ESCAPES 模式下转义文字百分比和下划线字符?的详细内容。更多信息请关注PHP中文网其他相关文章!