--====================================
--标题: 应用实例之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', @objRegexEx
SQL SERVER 正则匹配实例分享--【叶子】
最新推荐文章于 2024-10-30 11:19:43 发布