ERP俱乐部
ERP爱好者、ERP从业者互相交流、互相学习的乐园;我们的愿景是成为全球一流的中文ERP(Enterprise Resource Planning)交流平台
网站首页 论坛首页 搜索 用户列表 FAQ 注册 登录  
ERP俱乐部 -> 数据库专栏 -> MS SQL Server数据库 -> Re: SQL SERVER 正则匹配实例
  Re: SQL SERVER 正则匹配实例
帖子发起人: 失去的画布   发起时间: 2012-04-06 03:02 下午   回复数: 1
? 上一主题
楼主
  2012-04-06, 03:02 下午
失去的画布 离线,最后访问时间: 2012/5/21 11:03:41 失去的画布

无等级

10级
等级: 10级
注册: 2011年12月2日
经验: 12
积分: 12
精华: 0
发贴: 13
排名: 2,748
Site Registered Users
SQL SERVER 正则匹配实例
 
--====================================
--
标题: 应用实例之SQL SERVER 正则匹配
--
作者:maco_wang
--
时间:2012-03-25
--
说明:MS-SQL SERVER 中的正则匹配
--
====================================

/*
假设测试数据为:
col
----------
a b d c e
a a b c d
b b c d e
e u g h w
o a k d w

1)得到没有重复字母的行,即想要得到如下结果:
col
--------------
a b c d e
e u g h w
o p k n w

2)得到同时存在a和d,并且a和d之间只有0或是1个字母的,即想要得到的结果:
col
----------
a b d c e
o 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 all
select 'a a b c d' union all
select 'b b c d e' union all
select 'e u g h w' union all
select 'o a k d w'

select * from [tb]

--本示例在SQL SERVER 2000版本即可适用。

go
create function dbo.RegexMatch
(
@pattern varchar(2000),
@matchstring varchar(8000)
)
returns int
as
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 @match
end

go
--1)得到没有重复字母的行
--
正常思路,可能是按照空格分割后去重然后合并,最后判断长度(略)

--用正则就很方便了
select col from [tb] where dbo.RegexMatch('^.*?([a-z])[ ]\1.*?$',col)=0
/*
col
----------
a b d c e
e u g h w
o a k d w
*/

--2)得到同时存在a和d,并且a和d之间间隔小于等于一个字母的

--正常思路
select col from [tb]
where charindex('a',col)>0
and charindex('d',col)>0
and abs(charindex('a',col)-charindex('d',col))<5
/*
col
----------
a b d c e
o a k d w
*/
--正则处理
select col from [tb] where dbo.RegexMatch('.*a[a-z ]{1,3}d.*',col)=1
/*
col
----------
a b d c e
o 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 e
o a k d w
*/

分享按钮 IP 地址: 已登录   来自: 已登录    返回顶部
第 2 楼
  2013-07-24, 05:39 下午
summerlan 离线,最后访问时间: 2013/12/16 10:45:06 summerlan

发帖数前50位
女

70级
等级: 70级
注册: 2013年5月17日
经验: 501
积分: 642
精华: 0
发贴: 381
排名: 52
Site Registered Users
Re: SQL SERVER 正则匹配实例
 
谢谢分享!
来Yok !
You ok,so we ok
email:cuiqin.lan@yok.com.cn
tel:0755-26523860; 18038036868
MSN:yoksaphunter@hotmail.com
QQ:374439400
请关注亚可官方微博:
亚可YOK 、sapclub

IP 地址: 已登录   来自: 已登录    返回顶部
 第 1 页 总共 1 页 [共有 2 条记录]
ERP俱乐部 -> 数据库专栏 -> MS SQL Server数据库 -> Re: SQL SERVER 正则匹配实例
(C)Copyright 2005-2020 www.erpclub.org All Rights Reserved.
Tel:+86-755-26444630
Email:webmaster@yok.com.cn