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)中,它们就被当作普通字符对待了。
- 用 like '[[]' 匹配特殊字符 '['
select 1 where '[ABCDE' like '[[]%'
- 用 like ']' 匹配特殊字符 ']'
select 1 where ']ABCDE' like ']%'
- 用 like '[[]]' 匹配特殊字符 '[]'
select 1 where '[]ABCDE' like '[[]]%%'
- 用 like '[]' 匹配特殊字符 ''
select 1 where 'ABCDE' like '[]%'
- 用 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 ''
后记:用过正则表达式的朋友应该都知道,在正则表达式里可以用表示匹配0次或是多次, [\u4e00-\u9fa5]这个可以匹配中文,但在这里我没有发现类似的功能,所以匹配一些复杂的语句就比较头疼。如我要匹配形如:印张数量单价、200+印张数量单价、印张数量,但不匹配形如:印张数量5单价、印张数量6767、55印张数量uu的数据就很难实现了。
下面这个就是要匹配包括“纺梦”这两个字,但这两个字只能是与“+-*/”这四个字符相连或是单独存在。如果这里的“纺梦”是任意中文字符就没办法去处理了。
复制代码
create table #tbl(n int,v nvarchar(100))
insert into #tbl
select 1,'1+纺梦1+2'
union select 2,'1+纺梦+1'
union select 3,'纺梦'
union select 4,'纺梦+1'
select * from #tbl
where (v like '%[+-/]纺梦[+-/]%' ESCAPE '')
or (v like '纺梦[+-/]%' ESCAPE '')
or (v like '%[+-/]纺梦' ESCAPE '')
or (v = '纺梦')
--select * from #tbl
drop table #tbl
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
2018-06-16 gdb调试