亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

SqlServer類似正則表達(dá)式的字符處理問題

2024-08-31 01:05:13
字體:
供稿:網(wǎng)友

SQL Serve提供了簡單的字符模糊匹配功能,比如:like, patindex,不過對于某些字符處理場景還顯得并不足夠,日常碰到的幾個問題有:

1. 同一個字符/字符串,出現(xiàn)了多少次

2. 同一個字符,第N次出現(xiàn)的位置

3. 多個相同字符連續(xù),合并為一個字符

4. 是否為有效IP/身份證號/手機(jī)號等 

一. 同一個字符/字符串,出現(xiàn)了多少次

同一個字符,將其替換為空串,即可計算

declare @text varchar(1000)declare @str varchar(10)set @text = 'ABCBDBE'set @str = 'B'select len(@text) - len(replace(@text,@str,''))

同一個字符串,仍然是替換,因為是多個字符,方法1替換后需要做一次除法;方法2替換時增加一個字符,則不需要

--方法1declare @text varchar(1000)declare @str varchar(10)set @text = 'ABBBCBBBDBBBE'set @str = 'BBB'select (len(@text) - len(replace(@text,@str,'')))/len(@str)--方法2declare @text varchar(1000)declare @str varchar(10)set @text = 'ABBBCBBBDBBBE'set @str = 'BBB'select len(replace(@text,@str,@str+'_')) - len(@text)

二. 同一個字符/字符串,第N次出現(xiàn)的位置

SQL SERVER定位字符位置的函數(shù)為CHARINDEX:

CHARINDEX ( expressionToFind , expressionToSearch [ , start_location ] )

可以從指定位置起開始檢索,但是不能取第N次出現(xiàn)的位置,需要自己寫SQL來補(bǔ)充,有以下幾種思路:

1. 自定義函數(shù), 循環(huán)中每次為charindex加一個計數(shù),直到為N

if object_id('NthChar','FN') is not null  drop function NthcharGOcreate function NthChar(@source_string as nvarchar(4000), @sub_string  as nvarchar(1024),@nth      as int) returns int as begin   declare @postion int   declare @count  int   set @postion = CHARINDEX(@sub_string, @source_string)   set @count = 0   while @postion > 0   begin     set @count = @count + 1     if @count = @nth     begin       break     end    set @postion = CHARINDEX(@sub_string, @source_string, @postion + 1)   End   return @postion end GO--select dbo.NthChar('abcabc','abc',2)--4

2. 通過CTE,對待處理的整個表字段操作, 遞歸中每次為charindex加一個計數(shù),直到為N

if object_id('tempdb..#T') is not null  drop table #Tcreate table #T(source_string nvarchar(4000))insert into #T values (N'我們我們')insert into #T values (N'我我哦我')declare @sub_string nvarchar(1024)declare @nth    intset @sub_string = N'我們'set @nth = 2;with T(source_string, starts, pos, nth) as (  select source_string, 1, charindex(@sub_string, source_string), 1 from #t  union all  select source_string, pos + 1, charindex(@sub_string, source_string, pos + 1), nth+1 from T  where pos > 0)select   source_string, pos, nthfrom Twhere pos <> 0 and nth = @nthorder by source_string, starts--source_string  pos  nth--我們我們  3  2

3. 借助數(shù)字表 (tally table),到不同起點位置去做charindex,需要先自己構(gòu)造個數(shù)字表

--numbers/tally tableIF EXISTS (select * from dbo.sysobjects where id = object_id(N'[dbo].[Numbers]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)  DROP TABLE dbo.Numbers--===== Create and populate the Tally table on the fly SELECT TOP 1000000     IDENTITY(int,1,1) AS number  INTO dbo.Numbers  FROM master.dbo.syscolumns sc1,    master.dbo.syscolumns sc2--===== Add a Primary Key to maximize performance ALTER TABLE dbo.Numbers    ADD CONSTRAINT PK_numbers_number PRIMARY KEY CLUSTERED (number)--===== Allow the general public to use it GRANT SELECT ON dbo.Numbers TO PUBLIC--以上數(shù)字表創(chuàng)建一次即可,不需要每次都重復(fù)創(chuàng)建DECLARE @source_string  nvarchar(4000),     @sub_string    nvarchar(1024),     @nth       intSET @source_string = 'abcabcvvvvabc'SET @sub_string = 'abc'SET @nth = 2 ;WITH T AS(      SELECT ROW_NUMBER() OVER(ORDER BY number) AS nth,    number AS [Position In String] FROM dbo.Numbers n  WHERE n.number <= LEN(@source_string)    AND CHARINDEX(@sub_string, @source_string, n.number)-number = 0  ----OR  --AND SUBSTRING(@source_string,number,LEN(@sub_string)) = @sub_string) SELECT * FROM T WHERE nth = @nth

4. 通過CROSS APPLY結(jié)合charindex,適用于N值較小的時候,因為CROSS APPLY的次數(shù)要隨著N的變大而增加,語句也要做相應(yīng)的修改

declare @T table(source_string nvarchar(4000))insert into @T values('abcabc'),('abcabcvvvvabc')declare @sub_string nvarchar(1024)set @sub_string = 'abc'select source_string,    p1.pos as no1,    p2.pos as no2,    p3.pos as no3from @Tcross apply (select (charindex(@sub_string, source_string))) as P1(Pos)cross apply (select (charindex(@sub_string, source_string, P1.Pos+1))) as P2(Pos)cross apply (select (charindex(@sub_string, source_string, P2.Pos+1))) as P3(Pos)

5. 在SSIS里有內(nèi)置的函數(shù),但T-SQL中并沒有

--FINDSTRING in SQL Server 2005 SSISFINDSTRING([yourColumn], "|", 2),--TOKEN in SQL Server 2012 SSISTOKEN(Col1,"|",3)

注:不難發(fā)現(xiàn),這些方法和字符串拆分的邏輯是類似的,只不過一個是定位,一個是截取,如果要獲取第N個字符左右的一個/多個字符,有了N的位置,再結(jié)合substring去截取即可;

三. 多個相同字符連續(xù),合并為一個字符

最常見的就是把多個連續(xù)的空格合并為一個空格,解決思路有兩個:

1. 比較容易想到的就是用多個replace

但是究竟需要replace多少次并不確定,所以還得循環(huán)多次才行

--把兩個連續(xù)空格替換成一個空格,然后循環(huán),直到charindex檢查不到兩個連續(xù)空格declare @str varchar(100)set @str='abc    abc   kljlk   kljkl'while(charindex(' ',@str)>0)begin  select @str=replace(@str,' ',' ')endselect @str

2. 按照空格把字符串拆開

對每一段拆分開的字符串trim或者replace后,再用一個空格連接,有點繁瑣,沒寫代碼示例,如何拆分字符串可參考:“第N次出現(xiàn)的位置”;

四. 是否為有效IP/身份證號/手機(jī)號等

類似IP/身份證號/手機(jī)號等這些字符串,往往都有自身特定的規(guī)律,通過substring去逐位或逐段判斷是可以的,但SQL語句的方式往往性能不佳,建議嘗試正則函數(shù),見下。

五. 正則表達(dá)式函數(shù)

1. Oracle

從10g開始,可以在查詢中使用正則表達(dá)式,它通過一些支持正則表達(dá)式的函數(shù)來實現(xiàn):

Oracle 10 gREGEXP_LIKEREGEXP_REPLACEREGEXP_INSTRREGEXP_SUBSTROracle 11g (新增)REGEXP_COUNT

Oracle用REGEXP函數(shù)處理上面幾個問題:

(1) 同一個字符/字符串,出現(xiàn)了多少次

select length(regexp_replace('123-345-566', '[^-]', '')) from dual;select REGEXP_COUNT('123-345-566', '-') from dual; --Oracle 11g 

(2) 同一個字符/字符串,第N次出現(xiàn)的位置

不需要正則,ORACLE的instr可以直接查找位置:

instr('source_string','sub_string' [,n][,m])

n表示從第n個字符開始搜索,缺省值為1,m表示第m次出現(xiàn),缺省值為1。

select instr('abcdefghijkabc','abc', 1, 2) position from dual; 

(3) 多個相同字符連續(xù),合并為一個字符

select regexp_replace(trim('agc f  f '),'/s+',' ') from dual; 

(4) 是否為有效IP/身份證號/手機(jī)號等

--是否為有效IPWITH IPAS(SELECT '10.20.30.40' ip_address FROM dual UNION ALLSELECT 'a.b.c.d' ip_address FROM dual UNION ALLSELECT '256.123.0.254' ip_address FROM dual UNION ALLSELECT '255.255.255.255' ip_address FROM dual)SELECT *FROM IPWHERE REGEXP_LIKE(ip_address, '^(([0-9]{1}|[0-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])/.){3}([0-9]{1}|[0-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])$');--是否為有效身份證/手機(jī)號,暫未舉例

2. SQL Server

目前最新版本為SQL Server 2017,還沒有對REGEXP函數(shù)的支持,需要通用CLR來擴(kuò)展,如下為CLR實現(xiàn)REG_REPLACE:

--1. 開啟 CLR EXEC sp_configure 'show advanced options' , '1'GORECONFIGUREGOEXEC sp_configure 'clr enabled' , '1'GORECONFIGUREGOEXEC sp_configure 'show advanced options' , '0';GO

 2. 創(chuàng)建 Assembly

--3. 創(chuàng)建 CLR 函數(shù)CREATE FUNCTION [dbo].[regex_replace](@input [nvarchar](4000), @pattern [nvarchar](4000), @replacement [nvarchar](4000))RETURNS [nvarchar](4000) WITH EXECUTE AS CALLER, RETURNS NULL ON NULL INPUTAS EXTERNAL NAME [RegexUtility].[RegexUtility].[RegexReplaceDefault]GO--4. 使用regex_replace替換多個空格為一個空格select dbo.regex_replace('agc f  f ','/s+',' ');

注:通過CLR實現(xiàn)更多REGEXP函數(shù),如果有高級語言開發(fā)能力,可以自行開發(fā);或者直接使用一些開源貢獻(xiàn)也行,比如:http://devnambi.com/2016/sql-server-regex/

小結(jié):

1. 非正則SQL語句的思路,對不同數(shù)據(jù)庫往往都適用;

2. 正則表達(dá)式中的規(guī)則(pattern) 在不同開發(fā)語言里,有很多語法是相通的,通常是遵守perl或者linux shell中的sed等工具的規(guī)則;

3. 從性能上來看,通用SQL判斷 > REGEXP函數(shù) > 自定義SQL函數(shù)。

總結(jié)

以上所述是小編給大家介紹的SqlServer類似正則表達(dá)式的字符處理問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識閱讀請移步到MSSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
亚洲欧美日韩三级| 亚洲人精品午夜射精日韩| 乱中年女人伦av一区二区| 日韩av电影中文字幕| 五月婷婷久久丁香| 国产91视频一区| wwwav在线| 欧美日韩黄色大片| 欧美精选视频一区二区| 免费人成福利播放| 任我爽在线视频精品一| 国产精品久久久久久久免费软件| 91沈先生播放一区二区| 国产乱子伦精品无码专区| 欧美黄色免费网站| 欧美男女视频| av激情成人网| 无码h肉动漫在线观看| 国产成人综合av| 台湾佬综合网| 欧美精品一区视频| 亚洲激情视频小说| 中文字幕免费在线观看视频| 在线观看精品自拍视频| 国产精品一区2区3区| 国产欧美精品一区二区| 97精品人人妻人人| 中文字幕国产视频| 性猛交富婆╳xxx乱大交天津| 视频国产精品| 国产精品综合在线视频| 在线观看一区视频| 激情欧美成人久久综合小说| 国产精品嫩草影院一区二区| 中文字幕2019第三页| 九九热精品在线观看| 男人和女人做事情在线视频网站免费观看| 又黄又爽又色视频| 无码精品a∨在线观看中文| 性感av在线播放| 国产成人在线一区| 欧美zozo另类异族| 亚洲精品蜜桃乱晃| 日本一本高清视频| 4438x全国最大成人| jizz中国女人| 一色屋色费精品视频在线观看| 欧美日韩va| 色屁屁影院www国产高清麻豆| 领导边摸边吃奶边做爽在线观看| 天天综合亚洲| 黄色大片免费看| 成人高清电影网站| 成人性生交大片免费看视频r| 国产免费一区二区三区最新6| 亚洲香蕉伊综合在人在线视看| 国产传媒在线播放| 久久精品男女| 成人污网站在线观看| 日本黄色片一级片| 成人精品久久一区二区三区| 视频精品导航| 波多野结衣家庭教师| 国产日韩欧美电影在线观看| 欧美三级电影在线观看| 欧美精品观看| 国产麻豆剧传媒精品国产av| 日韩免费视频播放| 日韩最新在线| 精品福利樱桃av导航| 婷婷国产精品| **毛片在线网站| 青青在线免费观看视频| 色伦专区97中文字幕| 中文一区一区三区高中清不卡免费| 黄色片一级视频| 7777精品伊人久久久大香线蕉的| 亚洲涩涩在线观看| 亚洲视频axxx| 亚洲无限av看| 男女激情网站| 一级特黄免费视频| 中文字幕免费一区二区| heyzo在线观看| 婷婷久久综合九色综合绿巨人| 国产免费黄视频| 都市激情久久久久久久久久久| 亚洲人午夜射精精品日韩| 国内成人精品2018免费看| 大色综合视频网站在线播放| 免费欧美日韩国产三级电影| 亚洲精品va在线观看| 亚洲尤物影院| 国产在线拍揄自揄拍无码| 亚洲精品视频一二三| 国自产拍在线网站网址视频| 精品久久久久久国产91| 一不卡在线视频| 国产人妻精品久久久久野外| 欧美动物xxx| 无国产精品白浆免费视| 欧美洲成人男女午夜视频| 日本成人在线免费视频| www.天堂在线| 国产三级视频在线播放线观看| 久久精品女人的天堂av| 成人免费淫片免费观看| 亚洲精品国产高清久久伦理二区| 男人天堂av在线播放| 日韩一级在线免费观看| www.youjizz.com亚洲| 欧美午夜理伦三级在线观看| 国产999精品久久| 天天操天天干天天插| 国产精品精品国产| 亚洲自拍偷拍视频| 欧美一区二区三区在线观看| 成人av福利| 三上悠亚免费在线观看| 国产一区二区三区黄| 韩日欧美一区二区三区| 国色天香久久精品国产一区| 中文有码在线播放| 五月久久久综合一区二区小说| 国产在线成人| 第一福利永久视频精品| 亚洲精品色午夜无码专区日韩| 黄色小说在线观看视频| 久久久美女视频| 91精品国产91久久久| 男插女视频网站| 高清日韩电视剧大全免费| 青青草国产免费自拍| 色老头一区二区| 亚洲欧美另类在线观看| 中文字幕欧美激情| 日本激情小视频| 黄色成人在线网站| 国产在线电影| 在线观看日韩高清av| 欧美一级大片在线视频| 石原莉奈一区二区三区高清在线| 神马久久桃色视频| 99re8精品视频在线观看| 国产毛片毛片| 在线观看免费成人av| 艳妇乳肉豪妇荡乳av| 欧美日韩精品免费| 蜜桃久久精品一区二区| 国产精品亚洲欧美日韩一区在线| 精品福利网址导航| 波多野结衣日韩| 久久综合毛片| 国产日韩欧美麻豆| 中文字幕黄色网址| 久久精品国产一区二区三| 天天干在线影院| 成人av手机在线| 欧美性生给视频| 亚洲欧美一区二区三区四区| 亚洲人妖av一区二区| 日韩国产一二三区| 狠狠色丁香婷婷综合| 欧美精品一区二区三区久久久竹菊| 乱子伦一区二区| 欧美凹凸一区二区三区视频| 亚洲欧美三级伦理| 久久国产欧美精品| 中文字幕中文在线| 久久免费一级片| 丰满的少妇愉情hd高清果冻传媒| 免费电影网站在线视频观看福利| 一卡二卡3卡四卡高清精品视频| 国产精品白嫩美女在线观看| aaa在线视频| 99久久精品国产麻豆演员表| 99在线观看视频网站| 丰满人妻一区二区三区53视频| 欧美在线免费观看| 一区二区不卡免费视频| 亚洲成人av一区二区| 欧美日韩色图| 成人免费黄色网页| 91成人在线视频| 久久精品国产欧美亚洲人人爽| 久久高清精品| 国产毛片精品国产一区二区三区| 琪琪久久久久日韩精品| 国产成人a视频高清在线观看| 国产真实乱人偷精品人妻| 亚洲欧美一区二区三区情侣bbw| 精品福利网址导航| caoporn免费在线视频| 粉嫩av一区二区夜夜嗨| 国产欧美一区二区三区鸳鸯浴| 激情文学综合| 欧美久久影院| 北岛玲日韩精品一区二区三区| 神马久久影院| 97视频精彩视频在线观看| 亚洲美女精品视频| 国产91对白刺激露脸在线观看| 亚洲一区二区中文| 在线观看免费亚洲| 国产精品美女无圣光视频| 久草在线在线视频| 亚洲精品成人在线| 自拍偷拍在线视频| 国产又粗又猛又黄视频| 精品国产一区二区三区久久久| 91精品国产综合久久福利软件| 国产精品视频500部| 在线播放网站| 婷婷国产精品| 黄色动漫在线免费看| 欧美日韩黄色一区二区| 亚洲欧美日本一区二区三区| 特级西西444www大精品视频| 欧美特黄一级片| 久久日.com| 2022国产麻豆剧果冻传媒剧情| 亚洲三区在线观看| 欧美午夜黄色| 国产色视频一区| 99久久精品免费精品国产| 青草全福视在线| 国产免费av网站| 成人在线视频区| 成人做爰69片免费看网站| 欧美一区二区三区免费视| 天堂国产一区二区三区| 亚洲图片在线视频| 日本中文字幕一区二区有限公司| 天天爽天天狠久久久| 黑人巨大精品一区二区在线| 天堂网在线.www天堂在线视频| 夜夜嗨av色一区二区不卡| 久草在线官网| 国产亚洲第一区| 精品国产户外野外| 国产女同无遮挡互慰高潮91| 欧美人妻精品一区二区免费看| 口述被爽到呻吟高潮自述| 免费人成视频在线| www.99re7| 伊人22222| 亚洲精品免费在线观看| av激情综合网| 色噜噜国产精品视频一区二区| 在线成人国产| 中文字幕在线视频久| 欧美丰满日韩| 久久精品电影网| 激情欧美一区二区三区在线观看| 国产一级片免费观看| 老湿机69福利| 高清在线一区二区| 337p日本欧洲亚洲大胆张筱雨| 国产成人在线视频播放| 91精品国产高久久久久久五月天| 午夜精品www| 国产一区二区网址| 2021最新国产精品一区| 欧美日韩亚洲一区二区三区| 色综合97天天综合网| 在线观看国产v片| 99久精品国产| 日本韩国在线不卡| 动漫一区在线| 无需播放器的av| 最近日韩中文字幕| 久久丝袜视频| 蜜桃狠狠狠狠狠狠狠狠狠| ww亚洲ww在线观看国产| 综合五月激情网| 小视频在线播放| 午夜国产一区二区| 成人午夜激情免费视频| 国产精品久久久av久久久| 都市激情一区| 色一情一乱一乱一区91av| www.国产精品| 精品国产成人系列| 性xx色xx综合久久久xx| 久久久久久久久久久久久夜| 欧美老女人在线视频| 91搞黄在线观看| 99久久人妻无码精品系列| 欧美老女人性视频| 蜜桃传媒视频第一区入口在线看| 一区二区蜜桃| 日韩性生活视频| 成人免费无遮挡无码黄漫视频| 阿v视频在线观看| 久久无码高潮喷水| 精品一区二区三区五区六区七区| 欧美韩日高清| 欧美伦理视频网站| 欧美一级性视频| 国产一区二区电影在线观看| 在线观看免费视频你懂的| 国产网站在线免费观看| 国产成人天天5g影院在线观看| 中文字幕人妻一区二区三区视频| 中文字幕日本在线观看| 日本高清不卡一区二区三| 一个色综合av| 成人免费视频国产在线观看| 国产精品黄色av| 欧美精品a∨在线观看不卡| 国产乱色精品成人免费视频| 丰满少妇一区二区三区| 成人免费视频网站在线观看| 成人影片在线播放| 欧美gay囗交囗交| 欧美日韩国产成人高清视频| 在线亚洲自拍| 欧美精品在线一区| 99热在这里有精品免费| 亚洲综合图区| 日本一区二区久久精品| 日韩欧美在线播放| 中文字幕在线观看高清| 免费男女羞羞的视频网站中文字幕妖精视频| 国内精品久久久久久| 精品无码久久久久久久动漫| free性m.freesex欧美| 天天色综合色|