在 MySQL 5.7 中搜索反斜杠(\),对于 Like 时的转义,需要使用 \\\\

1、表中数据如下

INSERT INTO `object_store`.`theme_asset`(`id`, `theme_id`, `version`, `asset_key`, `mime_type`, `category`, `schema`, `created_at`, `updated_at`) VALUES (63, 'vogue', '', 'layouts\\basic.blade.php', 'text/html', 'unknown', NULL, '2022-02-15 09:59:41', '2022-02-15 09:59:41');

2、当在执行 where like 查询时,使用 like ‘layouts\\%’ 试图查询出以 layouts\ 开头的数据行。结果为空。如图1

图1

select
  `id`,
  `theme_id`,
  `version`,
  `asset_key`,
  `mime_type`,
  `category`,
  `schema`,
  `created_at`,
  `updated_at`
from
  `theme_asset`
where
  (
    `theme_id` = 'vogue'
    and `asset_key` like 'layouts\\%'
  )

3、当在执行 where like 查询时,使用 like ‘layouts\\\\%’ 试图查询出以 layouts\ 开头的数据行。才真正搜索出相应的结果。如图2

图2

select
  `id`,
  `theme_id`,
  `version`,
  `asset_key`,
  `mime_type`,
  `category`,
  `schema`,
  `created_at`,
  `updated_at`
from
  `theme_asset`
where
  (
    `theme_id` = 'vogue'
    and `asset_key` like 'layouts\\%'
  )

4、参考:https://dev.mysql.com/doc/refman/5.7/en/string-comparison-functions.html 。MySQL 在字符串中使用 C 转义语法(例如,\n 表示换行符)。如果您希望 LIKE 字符串包含文字 \,则必须将其加倍。(除非启用了 NO_BACKSLASH_ESCAPES SQL 模式,在这种情况下不使用转义字符。)例如,要搜索 \n,请将其指定为 \\n。 要搜索 \,请将其指定为 \\\\; 这是因为反斜杠被解析器剥离一次,并且在进行模式匹配时再次剥离,留下一个反斜杠进行匹配。如图3

图3

永夜