我试图过滤项与存储过程使用like。列是varchar(15)。我试图过滤的项目名称中有方括号。

例如:WC[R]S123456。

如果我做一个LIKE 'WC[R]S123456',它不会返回任何东西。

我找到了一些关于使用ESCAPE关键字LIKE的信息,但我如何使用它来将方括号作为常规字符串?


当前回答

如果需要搜索特殊字符,如%和_,则使用ESCAPE关键字,这些字符通常是通配符。如果指定了ESCAPE, SQL将逐字搜索字符%和_。

这是一篇有更多例子的好文章

SELECT columns FROM table WHERE 
    column LIKE '%[[]SQL Server Driver]%' 

-- or 

SELECT columns FROM table WHERE 
    column LIKE '%\[SQL Server Driver]%' ESCAPE '\'

其他回答

假设你想匹配字面量its[brac]et。

你不需要转义[],因为它只有在与[搭配使用时才有特殊的意义。

因此,逃跑就足以解决问题了。可以通过将[[]替换为[]来转义[。

LIKE 'WC[[]R]S123456' 

or

LIKE 'WC\[R]S123456' ESCAPE '\'

应该工作。

如果你需要转义像'_'(下划线)这样的特殊字符,就像我的例子一样,并且你不愿意/不能定义一个转义子句,你可能希望用方括号'['和']'把特殊字符括起来。

这解释了“奇怪的”字符串“[[]”的含义——它只是包含了“[”字符和方括号,有效地转义了它。

我的用例是指定一个存储过程的名称,其中带有下划线,作为Profiler的筛选条件。所以我把字符串'%name[_]的[_]一个[_]存储的[_]过程%'在TextData LIKE字段,它给了我跟踪结果,我想实现。

下面是文档中的一个很好的例子: LIKE (Transact-SQL) -使用通配符作为文字

下面是我实际使用的:

like 'WC![R]S123456' ESCAPE '!'

我需要从查询中排除以下划线开头的名称,所以我最终得到了这个:

WHERE b.[name] not like '\_%' escape '\'  -- use \ as the escape character