SQL Server:SQL Like 通配符特殊用法:Escape

本文深入探讨SQL中特殊字符的匹配方式,包括%、_、[]等符号的使用规则及示例,同时展示了如何利用SQL的escape子句处理其他特殊字符。通过具体的SQL语句演示,帮助读者掌握复杂字符串匹配技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转自:http://www.sqlstudy.com/sql_article.php?id=2008061601

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

SymbolMeaning
like '5'5%
like 'n'_n
like ''a, b, c, d, or f
like ''-, a, c, d, or f
like '[[]'']
like 'abcd%'abc_d and abc_de
like 'abc'abcd, abce, and abcf
like ''0
like ''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 'ABCDE'对于其他的特殊字符:'^', '-', ']' 因为它们本身在包含在 '[]' 中使用,所以需要用另外的方式来转义,于是就引入了 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' like '!]ABCDE' escape '!'
看出规律了吧,就是用 escape 后面紧跟着的字符来做转义字符。 escape 后面的字符相当于 C 语言字符串中的转义字符 '//'。
最后,看一个更加复杂的匹配

select 1 where 'ABCDE' like '//%' escape '//'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值