C#技术百科
问问你的心你有没有信心 做事情要专一坚定,执着

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

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]%')

posted on 2008-08-22 11:08  王德田  阅读(988)  评论(0编辑  收藏  举报