mysql中sql的正则使用,数据库中使用正则表达式小结

搜索热词

本篇文章通过两个示例给大家介绍数据库中使用正则表达式小结,在此不多说,具体内容请看下文详解吧。

示例一:

CREATE FUNCTION dbo.RegExpTest (

@source varchar(),--需要匹配的源字符串

@regexp varchar(),--正则表达式

@ignorecase bit = --是否区分大小写,默认为false

)

RETURNS bit --返回结果-false,-true

AS

BEGIN

--(成功)或非零数字(失败),是由OLE 自动化对象返回的HRESULT 的整数值。

DECLARE @hr integer

--用于保存返回的对象令牌,以便之后对该对象进行操作

DECLARE @objRegExp integer DECLARE @objMatches integer

--保存结果

DECLARE @results bit

/*

创建OLE 对象实例,只有sysadmin 固定服务器角色的成员才能执行sp_OACreate,并确定机器中有VBScript.RegExp类库

*/

EXEC @hr = sp_OACreate 'VBScript.RegExp',@objRegExp OUTPUT

IF @hr <> BEGIN

SET @results =

RETURN @results

END

/*

以下三个分别是设置新建对象的三个属性。下面是'VBScript.RegExp'中常用的属性举例:

Dim regEx,Match,Matches '建立变量。

Set regEx = New RegExp '建立一般表达式。

regEx.Pattern= patrn '设置模式。

regEx.IgnoreCase = True '设置是否区分大小写。

regEx.Global=True '设置全局可用性。

set Matches=regEx.Execute(string) '重复匹配集合

RegExpTest = regEx.Execute(strng) '执行搜索。

for each match in matches '重复匹配集合

RetStr=RetStr &"Match found at position "

RetStr=RetStr&Match.FirstIndex&".Match Value is '"

RetStr=RetStr&Match.Value&"'."&vbCRLF Next

RegExpTest=RetStr

*/

EXEC @hr = sp_OASetProperty @objRegExp,'Pattern',@regexp

IF @hr <> BEGIN

SET @results =

RETURN @results

END

EXEC @hr = sp_OASetProperty @objRegExp,'Global',false

IF @hr <> BEGIN

SET @results =

RETURN @results

END

EXEC @hr = sp_OASetProperty @objRegExp,'IgnoreCase',@ignorecase

IF @hr <> BEGIN

SET @results =

RETURN @results

END

--调用对象方法

EXEC @hr = sp_OAMethod @objRegExp,'Test',@results OUTPUT,@source

IF @hr <> BEGIN

SET @results =

RETURN @results

END

--释放已创建的OLE 对象

EXEC @hr = sp_OADestroy @objRegExp

IF @hr <> BEGIN

SET @results =

RETURN @results

END

RETURN @results

END

--打开高级选项

sp_configure 'show advanced options',reconfigure

--设置选项打开

sp_configure 'Ole Automation Procedures',reconfigure

示例二:

使用REGEXP和NOT REGEXP操作符(或RLIKE和NOT RLIKE,它们是同义词)进行匹配测试。

扩展正则表达式的一些字符是:

・         ‘.'匹配任何单个的字符。

・         字符类“[...]”匹配在方括号内的任何字符。例如,“[abc]”匹配“a”、“b”或“c”。为了命名字符的范围,使用一个“-”。“[a-z]”匹配任何字母,而“[0-9]”匹配任何数字。

・         “ * ”匹配零个或多个在它前面的字符。例如,“x*”匹配任何数量的“x”字符,“[0-9]*”匹配任何数量的数字,而“.*”匹配任何数量的任何字符。

如果REGEXP模式与被测试值的任何地方匹配,模式就匹配(这不同于LIKE模式匹配,只有与整个值匹配,模式才匹配)。

为了定位一个模式以便它必须匹配被测试值的开始或结尾,在模式开始处使用“^”或在模式的结尾用“$”。

查询myname中以w开头的数据:

df2cf5c5cd7b491523d79f08947e31bb.png

查询myname中以g结尾的数据:

61325d22ea678a85bb5a6fb95a2bc6d0.png

查询包含w的数据:

dbc09870458c1ebb9885631611fec6e5.png

包含六个字符的数据:

c76d68fa3e08e88daf2b861584a980de.png

可以使用“{n}”“重复n次”操作符:

73a51f7afe0d9e68398fc0835fef1a0d.png

以上内容是编程小技巧小编给大家通过两段示例给大家分享的数据库中使用正则表达式小结,希望对大家有所帮助。

总结

以上是编程之家为你收集整理的数据库中使用正则表达式小结全部内容,希望文章能够帮你解决数据库中使用正则表达式小结所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值