在 MySQL 5.7 中搜索反斜杠(\),对于 Like 时的转义,需要使用 \\\\
1、表中数据如下
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 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | 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
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | 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
近期评论