在 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
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
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
近期评论