各位用户为了找寻关于SQL Server中利用正则表达式替换字符串的方法的资料费劲了很多周折。这里教程网为您整理了关于SQL Server中利用正则表达式替换字符串的方法的相关资料,仅供查阅,以下为您介绍关于SQL Server中利用正则表达式替换字符串的方法的详细内容
建立正则替换函数,利用了OLE对象,以下是函数代码:
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34--如果存在则删除原有函数
IF OBJECT_ID(N
'dbo.RegexReplace'
)
IS
NOT
NULL
DROP
FUNCTION
dbo.RegexReplace
GO
--开始创建正则替换函数
CREATE
FUNCTION
dbo.RegexReplace
(
@string
VARCHAR
(
MAX
),
--被替换的字符串
@pattern
VARCHAR
(255),
--替换模板
@replacestr
VARCHAR
(255),
--替换后的字符串
@IgnoreCase
INT
= 0
--0区分大小写 1不区分大小写
)
RETURNS
VARCHAR
(8000)
AS
BEGIN
DECLARE
@objRegex
INT
, @retstr
VARCHAR
(8000)
--创建对象
EXEC
sp_OACreate
'VBScript.RegExp'
, @objRegex
OUT
--设置属性
EXEC
sp_OASetProperty @objRegex,
'Pattern'
, @pattern
EXEC
sp_OASetProperty @objRegex,
'IgnoreCase'
, @IgnoreCase
EXEC
sp_OASetProperty @objRegex,
'Global'
, 1
--执行
EXEC
sp_OAMethod @objRegex,
'Replace'
, @retstr
OUT
, @string, @replacestr
--释放
EXECUTE
sp_OADestroy @objRegex
RETURN
@retstr
END
GO
--保证正常运行的话,需要将Ole Automation Procedures选项置为1
EXEC
sp_configure
'show advanced options'
, 1
RECONFIGURE
WITH
OVERRIDE
EXEC
sp_configure
'Ole Automation Procedures'
, 1
RECONFIGURE
WITH
OVERRIDE
?
1
2
3
4
5
6
7
--2.将姓名倒过来
SELECT
dbo.RegexReplace(
'John Smith'
,
'([a-z]+)s([a-z]+)'
,
'$2,$1'
,1)
/*
--------------------------------------
Smith,John
*/
--------------------------------------------------
只有对写程序充满热情,才能写出好的程序!
以上所述是小编给大家介绍的SQL Server中利用正则表达式替换字符串的方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言小编会及时回复大家的!
原文链接:http://www.cnblogs.com/zhangwc/archive/2017/03/03/6497373.html