原文鏈接:https://blog.csdn.net/feng19821209/article/details/38759417
1.使用 ESCAPE 關鍵字,定義轉義符。在模式中,當轉義符置於通配符之前時,該通配符就解釋爲普通字符。例如,要搜索在任意位置包含字符串 5% 的字符串,請使用:
WHERE ColumnA LIKE '%5/%%' ESCAPE '/'
2.ESCAPE 'escape_character'
允許在字符串中搜索通配符而不是將其作爲通配符使用。escape_character 是放在通配符前表示此特殊用途的字符。
SELECT *
FROM finances
WHERE description LIKE 'gs_' ESCAPE 'S'
GO
意思就是:
比如,我們要搜索一個字符串 "g_" ,如果直接 like "g_",那麼 "_"的作用就是通配符,而不是字符,結果,我們會查到比如 "ga","gb","gc",而不是我們需要的 "g_".
用 LIKE 'gs_' ESCAPE 'S' 's'表示特殊用法標誌
3.create table a (name varchar(10))
go
insert into a select '11%22'
union all select '11%33'
union all select '12%33'
go
select * from a WHERE name LIKE '%/%33' ESCAPE '/' --指定用'/'符號來說明跟在其後面的通配符字符爲普能字符。(第二個%是字符不是通配符來的)
結果爲:
name
----------
11%33
12%33
%:匹配零個及多個任意字符; _:與任意單字符匹配; []:匹配一個範圍; [^]:排除一個範圍
Symbol | Meaning |
---|---|
like '5[%]' | 5% |
like '[_]n' | _n |
like '[a-cdf]' | a, b, c, d, or f |
like '[-acdf]' | -, a, c, d, or f |
like '[[]' | [ |
like ']' | ] |
like 'abc[_]d%' | abc_d and abc_de |
like 'abc[def]' | abcd, abce, and abcf |
like '[^1-9]' | 0 |
like '[^1-9b-z]' | 0, a |
對於字符串中出現的特殊字符:'%','[','[]', '_' 可以使用 '[]' 把它們包含起來, 這樣在匹配模式(pattern)中,它們就被當作普通字符對待了。
1. 用 like '[[]' 匹配特殊字符 '['
select 1 where '[ABCDE' like '[[]%'
2. 用 like ']' 匹配特殊字符 ']'
select 1 where ']ABCDE' like ']%'
3. 用 like '[[]]' 匹配特殊字符 '[]'
select 1 where '[]ABCDE' like '[[]]%%'
4. 用 like '[_]' 匹配特殊字符 '_'
select 1 where '_ABCDE' like '[_]%'
5. 用 like '[%]' 匹配特殊字符 '%'
select 1 where 'ABC%DE' like 'ABC[%]DE'
對於其他的特殊字符:'^', '-', ']' 因爲它們本身在包含在 '[]' 中使用,所以需要用另外的方式來轉義,於是就引入了 like 中的 escape 子句,另外值得注意的是:escape 可以轉義所有的特殊字符。
select 1 where '^ABCDE' like '!^ABCDE' escape '!' select 1 where '-ABCDE' like '!-ABCDE' escape '!' select 1 where ']ABCDE' like '!]ABCDE' escape '!' select 1 where '%ABCDE' like '\%ABCDE' escape '\' select 1 where '%ABCDE' like '!%ABCDE' escape '!' select 1 where '%ABCDE' like '#%ABCDE' escape '#' select 1 where '%ABCDE' like '@%ABCDE' escape '@' select 1 where '[ABCDE' like '![ABCDE' escape '!' select 1 where ']ABCDE' like '!]ABCDE' escape '!'
看出規律了吧,就是用 escape 後面緊跟着的字符來做轉義字符。 escape 後面的字符相當於 C 語言字符串中的轉義字符 '\'。
最後,看一個更加複雜的匹配
select 1 where '[^A-Z]ABCDE' like '\[\^A\-Z\]%' escape '\'