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

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

当在执行 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

当在执行 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

参考: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

(0)
上一篇 2022年4月29日
下一篇 2022年4月29日

相关推荐

发表回复

登录后才能评论