SQL Server:SQL Like 萬用字元特殊用法:Escape
%:匹配零個及多個任一字元; _:與任意單字元匹配; []:匹配一個範圍; [^]:排除一個範圍
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 '\'