日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

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

發(fā)布時間:2023/12/13 数据库 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SQL Server:SQL Like 通配符特殊用法:Escape 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

?


%:匹配零個及多個任意字符; _:與任意單字符匹配; []:匹配一個范圍; [^]:排除一個范圍?;-:連字符

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

對于字符串中出現(xiàn)的特殊字符:'%','[','[]', '_' 可以使用 '[]' 把它們包含起來,這樣在匹配模式(pattern)中,它們就被當(dāng)作普通字符對待了。

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'

?

對于其他的特殊字符:'^', '-', ']' 因為它們本身在包含在 '[]' 中使用,所以需要用另外的方式來轉(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 后面緊跟著的字符來做轉(zhuǎn)義字符。 escape 后面的字符相當(dāng)于 C 語言字符串中的轉(zhuǎn)義字符 '\'。

最后,看一個更加復(fù)雜的匹配,注意“-”這個也是特殊字符也需轉(zhuǎn)義。

select 1 where '[^A-Z]ABCDE' like '\[\^A\-Z\]%' escape '\'

?

后記:用過正則表達(dá)式的朋友應(yīng)該都知道,在正則表達(dá)式里可以用*表示匹配0次或是多次,?[\u4e00-\u9fa5]這個可以匹配中文,但在這里我沒有發(fā)現(xiàn)類似的功能,所以匹配一些復(fù)雜的語句就比較頭疼。如我要匹配形如:印張數(shù)量*單價、200+印張數(shù)量*單價、印張數(shù)量,但不匹配形如:印張數(shù)量5*單價、印張數(shù)量6767、55印張數(shù)量uu的數(shù)據(jù)就很難實現(xiàn)了。

下面這個就是要匹配包括“紡夢”這兩個字,但這兩個字只能是與“+-*/”這四個字符相連或是單獨存在。如果這里的“紡夢”是任意中文字符就沒辦法去處理了。

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

?

轉(zhuǎn)載于:https://www.cnblogs.com/yangmingyu/p/6928209.html

總結(jié)

以上是生活随笔為你收集整理的SQL Server:SQL Like 通配符特殊用法:Escape的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。