1、表中数据如下
INSERT INTO `wshop_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
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/250320.html