SQL Server:Like 通配符特殊用法:Escape
%:匹配零個(gè)及多個(gè)任意字符; _:與任意單字符匹配; []:匹配一個(gè)范圍; [^]:排除一個(gè)范圍
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
對(duì)于字符串中出現(xiàn)的特殊字符:'%','[','[]', '_' 可以使用 '[]' 把它們包含起來(lái), 這樣在匹配模式(pattern)中,它們就被當(dāng)作普通字符對(duì)待了。
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'
對(duì)于其他的特殊字符:'^', '-', ']' 因?yàn)樗鼈儽旧碓诎?'[]' 中使用,所以需要用另外的方式來(lái)轉(zhuǎn)義,于是就引入了 like 中的 escape 子句,另外值得注意的是:escape 可以轉(zhuǎn)義所有的特殊字符。
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 '!'
看出規(guī)律了吧,就是用 escape 后面緊跟著的字符來(lái)做轉(zhuǎn)義字符。 escape 后面的字符相當(dāng)于 C 語(yǔ)言字符串中的轉(zhuǎn)義字符 '\'。
最后,看一個(gè)更加復(fù)雜的匹配
select 1 where '[^A-Z]ABCDE' like '\[\^A\-Z\]%' escape '\'
?
來(lái)源:http://www.sqlstudy.com/sql_article.php?id=2008061601
參考:http://zhidao.baidu.com/question/487621467.html
轉(zhuǎn)載于:https://blog.51cto.com/332374363/1068401
總結(jié)
以上是生活随笔為你收集整理的SQL Server:Like 通配符特殊用法:Escape的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Androidの多线程之更新ui(Thr
- 下一篇: LG 买下 58 个易被诈骗分子利用的域