现在的位置: 首页 > 综合 > 正文

数据库中的正则表达式函数

2013年07月16日 ⁄ 综合 ⁄ 共 1190字 ⁄ 字号 评论关闭

数据库中的正则表达式函数

CREATE function dbo.regexReplace
(
@source varchar(5000),    --原字符串
@regexp varchar(1000),    --正则表达式
@replace varchar(1000),   --替换值
@globalReplace bit = 0,   --是否是全局替换
@ignoreCase bit = 0       --是否忽略大小写
)
returnS varchar(1000AS
begin
declare @hr integer
declare @objRegExp integer
declare @result varchar(5000)

exec @hr = sp_OACreate 'VBScript.RegExp'@objRegExp OUTPUT
IF @hr <> 0 begin
exec @hr = sp_OADestroy @objRegExp
return null
end
exec @hr = sp_OASetProperty @objRegExp'Pattern'@regexp
IF @hr <> 0 begin
exec @hr = sp_OADestroy @objRegExp
return null
end
exec @hr = sp_OASetProperty @objRegExp'Global'@globalReplace
IF @hr <> 0 begin
exec @hr = sp_OADestroy @objRegExp
return null
end
exec @hr = sp_OASetProperty @objRegExp'IgnoreCase'@ignoreCase
IF @hr <> 0 begin
exec @hr = sp_OADestroy @objRegExp
return null
end 
exec @hr = sp_OAMethod @objRegExp'Replace'@result OUTPUT, @source@replace
IF @hr <> 0 begin
exec @hr = sp_OADestroy @objRegExp
return null
end
exec @hr = sp_OADestroy @objRegExp
IF @hr <> 0 begin
return null
end

return @result
end
例子

select dbo.regexReplace(u_account,'[ |=|の|-|〔|〕|:|[|.| |/|`|?|”|!|□|_|]|"|.|^|♂|+|~|‘]','',1,1) from userinfo WHERE (U_Account like '%[^a-zA-Z0-9]%')

抱歉!评论已关闭.