T-SQL - 如何在LIKE子句中转义斜杠/方括号
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了T-SQL - 如何在LIKE子句中转义斜杠/方括号相关的知识,希望对你有一定的参考价值。
我正在尝试对多个值使用T-SQL LIKE。经过我的研究,最简单的方法似乎是:
SELECT Column1
FROM Table_1
WHERE Column1 LIKE '[A,B,C]%'
所以我可以期望输出看起来像A1,B2,C3 ......
我的问题是我的场景的元素(A,B,C)格式为“X / Y / Z” - 是的,包含斜杠!斜杠将被视为分隔符 - 与逗号相同。例如,我想选择纽约,东京和伦敦的任何地方,所以我写道:
WHERE Location LIKE '[US/New York, Japan/Tokyo, UK/London]%'
但它确实如此
WHERE Location LIKE '[US,New York, Japan, Tokyo, UK, London]%'
它将返回US / LA / CBD或东京/塔...
任何人都可以点亮我的方式如何在LIKE条款的方括号内逃避斜线?提前谢谢了。
这是示例表:
DECLARE @temp TABLE (Location NVARCHAR(50))
INSERT INTO @temp (Location ) VALUES ('US/New York/A')
INSERT INTO @temp (Location ) VALUES('New York/B')
INSERT INTO @temp (Location ) VALUES ('Japan/Tokyo/C')
INSERT INTO @temp (Location ) VALUES ('Tokyo/D')
INSERT INTO @temp (Location ) VALUES ('UK/London/E')
INSERT INTO @temp (Location ) VALUES('London/F')
以下是我的草稿脚本:
SELECT *
FROM @temp
WHERE Location LIKE '[US/New York, Japan/Tokyo, UK/London]%'
我期待输出是:美国/纽约/日本/东京/英国/伦敦/ E,但实际上所有这些都将被撤出。
DECLARE @temp TABLE ( Location NVARCHAR(50) )
INSERT @temp (Location )
VALUES ('US/New York/A')
, ('New York/B')
, ('Japan/Tokyo/A')
, ('Tokyo/B')
, ('UK/London/A')
, ('London/B')
Select *
From @temp
Where Location Like '%/A'
在这种情况下,没有必要逃避/
。您只需使用带有尾随通配符的表达式即可。
Edit based on change to OP
看来你可能对如何在LIKE函数中解释[]
模式有误解。当你有像'[US/New York]%'
这样的模式时,它会说“找到以下列任何字符开头的值U
,S
,/
,N
,e
,w
,(space),Y
,o
,r
或k
。模式会找到一个值South Africa
或Outer Mongolia
。它不会查找整个值等于US/New York
的行。
实现目标的一种方法是使用多个Or
语句:
Select *
From @temp
Where Location Like 'US/New York%'
Or Location Like 'Japan/Tokyo%'
Or Location Like 'UK/London%'
declare @str nvarchar(10);
set @str='X/Y/Z';
SELECT name FROM dbo.Slash WHERE name LIKE @str+'%'
它将检索X / Y / Z1,X / Y / Z,..
试试这个 -
DECLARE @temp TABLE (name NVARCHAR(50))
INSERT INTO @temp (name)
VALUES ('Ben S'), ('test')
SELECT DISTINCT t.*
FROM @temp t
CROSS JOIN (
SELECT *
FROM (VALUES ('A'), ('B'), ('C')) t(t2)
) t2
WHERE t.name LIKE '%' + t2 + '%'
或试试这个 -
SELECT t.*
FROM @temp t
WHERE EXISTS(
SELECT 1
FROM (VALUES ('A'), ('B'), ('C')) c(t2)
WHERE t.name LIKE '%' + t2 + '%'
)
尝试将路径分隔符与有效字符范围分开。
WHERE name LIKE '%[/][A-Z][/][A-Z]_'
这将匹配像blabla / A / A1和xxx / B / B1这样的字符串
编辑:括号被视为'允许的字符集'。根据你的改述问题,我认为你可以通过简单地将一些通配符与一些文字值组合起来。以下是一些示例:
以斜线B结尾:
SELECT *
FROM @temp
WHERE Location LIKE '%/B'
以斜线“任何单个字符”结尾
SELECT *
FROM @temp
WHERE Location LIKE '%/_'
从Londen开始 - 任意数量的字符 - 以斜线“任何单个字符”结尾
SELECT *
FROM @temp
WHERE Location LIKE 'London%/_'
- 任何地方都有Londen,以斜线“任何单个角色”结尾
SELECT *
FROM @temp
WHERE Location LIKE '%London%/_'
以上是关于T-SQL - 如何在LIKE子句中转义斜杠/方括号的主要内容,如果未能解决你的问题,请参考以下文章
如何在VIM findsearch中转义反斜杠和正斜杠?[重复]