SQL Server中利用正则表达式替换字符串

原文:SQL Server中利用正则表达式替换字符串

建立正则替换函数,利用了OLE对象,以下是函数代码:

--如果存在则删除原有函数
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 

复制以上代码,到SQL中执行

然后测试,如下

--2.将姓名倒过来
SELECT dbo.RegexReplace(‘John Smith‘, ‘([a-z]+)\s([a-z]+)‘, ‘$2,$1‘,1)
/*
--------------------------------------
Smith,John
*/  

原文地址:https://www.cnblogs.com/lonelyxmas/p/11294576.html

时间: 2024-10-10 10:16:18

SQL Server中利用正则表达式替换字符串的相关文章

SQL Server中使用正则表达式

SQL Server 2005及以上版本支持用CLR语言(C# .NET.VB.NET)编写过程.触发器和函数,因此使得正则匹配,数据提取能够在SQL中灵活运用,大大提高了SQL处理字符串,文本等内容的灵活性及高效性. 操作步骤: 1.新建一个SQL Server项目(输入用户名,密码,选择DB),新建好后,可以在属性中更改的 2.新建一个类“RegexMatch.cs”,选择用户定义的函数 可以看到,该类为一个部分类:public partial class UserDefinedFuncti

JS 利用正则表达式替换字符串

JS 利用正则表达式替换字符串 博客分类: JavaScript 学习资料 Java代码 收藏代码 JS 利用正则表达式替换字符串 var data = "123123,213,12312,312,3,Caat,cat,dsfsdfs,"; var reCat = /\bc([a-z]|[A-Z]|[0-9])*t\b/ig; //•g(全文查找):•i(忽略大小写):•m(多行查找) var res = data.replace(reCat,"AAA"); 输出:

C#中利用正则表达式实现字符串搜索

摘要:本文给出了在C#下利用正则表达式实现字符串搜索功能的方法,通过对.NET框架下的正则表达式的研究及实例分析,总结了正则表达式的元字符.规则.选项等.1.正则表达式简介正则表达式提供了功能强大.灵活而又高效的方法来处理文本.正则表达式的全面模式匹配表示法可以快速地分析大量的文本以找到特定的字符模式;提? ⒈嗉⑻婊换蛏境谋咀幼址?或将提取的字符串添加到集合以生成报告.对于处理字符串(例?HTML 处理.日志文件分析和 HTTP 标头分析)的许多应用程序而言,正则表达式是不可缺少的工具..

SQL Server中如何把 科学记数法字符串 变为 数字字符串

当我们将Excel的数据导入SQL Server时,如果用SQL Server的字符串类型(VARCHAR和NVARCHAR等)来存储从Excel导入的数字,有时候这些数字会变成科学记数法字符串(例如'1.23E+10'实际上是'12300000000'). 这并不是我们想要的结果,我们希望从Excel导入的数字还是数字字符串,而不是科学记数法. 在SQL Server中我们可以通过这个思路来将 科学记数法字符串 变为 数字字符串: 首先将 科学记数法字符串 转换为 FLOAT类型 接着将 FL

Sql Server中Float格式转换字符串varchar方法(转)

SELECT CONVERT(varchar(100), CAST(@testFloat AS decimal(38,2)))SELECT STR(@testFloat, 38, 2) 从Excel中导入到sql2000,有一列“联系方式”变成了float类型,我想转换成nvarchar类型,用下面的语句 select convert(nvarchar(30),convert(int,联系方式)) from employeego //数据溢出,不行! select convert(nvarcha

SQL Server 2005,2008 正则表达式 替换函数应用详解

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

在sql server中利用with as实现递归功能

在sqlserver2005之前,要实现递归功能比较麻烦,比如可能会要用到临时表与while语句来循环.自sqlserver2005之后,新增了with as功能语法,即 公用表达式(CTE),让递归实现起来变的简单了. 本章我们主要演示如何利用with as功能实现一个简单的递归功能.在这之前先看一下cte的语法: [ WITH <common_table_expression > [ ,...n ] ]<common_table_expression >::= expressi

在Sql Server 中使用正则表达式

CREATE FUNCTION dbo.find_regular_expression ( @source varchar(5000), --需要匹配的源字符串 @regexp varchar(1000), --正则表达式 @ignorecase bit = 0 --是否区分大小写,默认为false ) RETURNS bit --返回结果0-false,1-true AS BEGIN --0(成功)或非零数字(失败),是由 OLE 自动化对象返回的 HRESULT 的整数值. DECLARE

Sql Server 中利用Convert 函数转换Datetime 到 String

CONVERT(varchar(10), date, 23) 1    02/22/06            CONVERT(varchar(10), date, 1) 0 Feb 22 2006 4:26PM CONVERT(CHAR(19), CURRENT_TIMESTAMP, 0) 1 02/22/06 CONVERT(CHAR(8), CURRENT_TIMESTAMP, 1) 2 06.02.22 CONVERT(CHAR(8), CURRENT_TIMESTAMP, 2) 3 2