SQL SERVER 正则匹配实例分享--【叶子】
--====================================--标题: 应用实例之SQL SERVER 正则匹配--作者:maco_wang--时间:2012-03-25--说明:MS-SQL SERVER 中的正则匹配--====================================/*假设测试数据为:col----------a b d c ea a b c db b c d ee u g h wo a k d w1)得到没有重复字母的行,即想要得到如下结果:col--------------a b c d ee u g h wo p k n w2)得到同时存在a和d,并且a和d之间只有0或是1个字母的,即想要得到的结果:col----------a b d c eo a k d w*/--测试数据if object_id('[tb]') is not null drop table [tb]create table [tb] (col varchar(10))insert into [tb]select 'a b d c e' union allselect 'a a b c d' union allselect 'b b c d e' union allselect 'e u g h w' union allselect 'o a k d w' select * from [tb]--本示例在SQL SERVER 2000版本即可适用。gocreate function dbo.RegexMatch( @pattern varchar(2000), @matchstring varchar(8000))returns intas begin declare @objRegexExp int declare @strErrorMessage varchar(255) declare @hr int,@match bit exec @hr= sp_OACreate 'VBScript.RegExp', @objRegexExp out if @hr = 0 exec @hr= sp_OASetProperty @objRegexExp, 'Pattern', @pattern if @hr = 0 exec @hr= sp_OASetProperty @objRegexExp, 'IgnoreCase', 1 if @hr = 0 exec @hr= sp_OAMethod @objRegexExp, 'Test', @match OUT, @matchstring if @hr <>0 begin return null end exec sp_OADestroy @objRegexExp return @matchendgo--1)得到没有重复字母的行--正常思路,可能是按照空格分割后去重然后合并,最后判断长度(略)--用正则就很方便了select col from [tb] where dbo.RegexMatch('^.*?([a-z])[ ]\1.*?$',col)=0/*col----------a b d c ee u g h wo a k d w*/--2)得到同时存在a和d,并且a和d之间间隔小于等于一个字母的--正常思路select col from [tb] where charindex('a',col)>0and charindex('d',col)>0and abs(charindex('a',col)-charindex('d',col))<5/*col----------a b d c eo a k d w*/--正则处理select col from [tb] where dbo.RegexMatch('.*a[a-z ]{1,3}d.*',col)=1/*col----------a b d c eo a k d w*/--这里的正则写法考虑的就不全,如果d在a前面呢?--那么修正一下select col from [tb] where dbo.RegexMatch('.*d[a-z ]{1,3}a.*|.*a[a-z ]{1,3}d.*',col)=1/*col----------a b d c eo a k d w*/