码迷,mamicode.com
首页 > 数据库 > 详细

SqlServer中使用正则表达式

时间:2014-08-28 13:08:59      阅读:306      评论:0      收藏:0      [点我收藏+]

标签:des   blog   http   使用   io   ar   数据   2014   cti   

一、查看配置,如果‘show advanced options’,‘Ole Automation Procedures’,‘Ad Hoc Distributed Queries’的config_value和run_value不为1,需要执行二中脚本。

bubuko.com,布布扣

二、执行脚本,打开SQL Server 对组件的访问阻止。

USE master
GO
sp_configure ‘show advanced options‘, 1;
GO
RECONFIGURE;
GO
sp_configure ‘Ole Automation Procedures‘, 1;
GO
RECONFIGURE;
GO
sp_configure ‘Ad Hoc Distributed Queries‘, 1;
GO
RECONFIGURE;
GO

 

三、创建函数(除数据库名和函数名外其他保持不变即可)

Use EDRMSOfficeDB;--(数据库名)
GO
if object_id(N‘dbo.Reg‘) is not null --(函数名)
drop function dbo.Reg;
GO
CREATE FUNCTION Reg
(
@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

四、测试

查询字段中含有出字母和数字之外的记录:

SELECT CategoryId FROM Category WHERE dbo.Reg(‘^[A-Za-z0-9]+$‘,CategoryId )=0

 

SqlServer中使用正则表达式

标签:des   blog   http   使用   io   ar   数据   2014   cti   

原文地址:http://www.cnblogs.com/surfing/p/3941239.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!