SQL SERVER 正则匹配实例分享--【叶子】

本文由maco_wang分享,介绍了SQL SERVER中如何使用正则表达式进行数据匹配。通过创建自定义函数`dbo.RegexMatch`,演示了如何找出没有重复字母的行以及如何查找a和d之间间隔小于等于一个字母的行。提供了多个测试用例展示正则表达式的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

--====================================
--标题: 应用实例之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
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值