SQL Server 转义字符序列 like escape的使用方法

来源:互联网 发布:梁边妖 知乎 编辑:程序博客网 时间:2024/05/19 09:01
 

%:匹配零个及多个任意字符; _:与任意单字符匹配; []:匹配一个范围; [^]:排除一个范围


 引用内容
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 '\'

 以上内容转摘自(CNode.CN)详细出处请参考:http://www.cnode.cn/article.asp?id=265