在HANA Query中,需要一个函数来从字符串中提取数字

2020-08-27 20:46发布

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


我将使用代码从字符串中提取数字

如何从汉娜中的字符串中提取数字

SQL代码:

创建函数dbo.udf_GetNumeric(@strAlphaNumeric VARCHAR(256))返回VARCHAR(256)AS
BEGIN
DECLARE @intAlpha INT

SET @intAlpha = PATINDEX('%[^ 0-9]%',@strAlphaNumeric)

开始

@intAlpha> 0

BEGIN
SET @strAlphaNumeric = STUFF(@strAlphaNumeric,@intAlpha,1,'')

SET @intAlpha = PATINDEX('%[^ 0-9]%',@strAlphaNumeric)

END
END
返回ISNULL(@ strAlphaNumeric,0)

END

GO

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


我将使用代码从字符串中提取数字

如何从汉娜中的字符串中提取数字

SQL代码:

创建函数dbo.udf_GetNumeric(@strAlphaNumeric VARCHAR(256))返回VARCHAR(256)AS
BEGIN
DECLARE @intAlpha INT

SET @intAlpha = PATINDEX('%[^ 0-9]%',@strAlphaNumeric)

开始

@intAlpha> 0

BEGIN
SET @strAlphaNumeric = STUFF(@strAlphaNumeric,@intAlpha,1,'')

SET @intAlpha = PATINDEX('%[^ 0-9]%',@strAlphaNumeric)

END
END
返回ISNULL(@ strAlphaNumeric,0)

END

GO

付费偷看设置
发送
3条回答
愤怒的猪头君
1楼 · 2020-08-27 21:03.采纳回答

要像示例一样从字符串中提取一个数字,可以使用 REPLACE_REGEXPR 函数。

根据虚拟对象的结果,选择replace_regexpr('S4000%55U5U5U2'中的'\ D'为''); 
软件心理学工程师
2楼-- · 2020-08-27 20:49

您的字符串有哪些示例? 它仅包含您要提取的一个数字还是几个数字?

Cikesha
3楼-- · 2020-08-27 21:08

这是输入字符串'S4000%55U5U5U2'

我需要输出为'400055552'

我需要提取几个数字。

一周热门 更多>