sql 分隔字符串并相加

本文介绍了两种在Oracle数据库中处理字符串的方法,包括创建函数实现字符串分隔并求和,以及利用正则表达式进行操作。通过这些技巧,可以有效地对包含逗号分隔数值的字符串进行计算。
摘要由CSDN通过智能技术生成

1.第一种方法 :oracle 创建函数

CREATE OR REPLACE FUNCTION sumstrsplitBySep(str VARCHAR2 ,sep VARCHAR2)
RETURN VARCHAR2
IS
RES VARCHAR2(100);
TEMP VARCHAR2(100) :=STR;
S_INDEX NUMBER;
BEGIN
	LOOP
		S_INDEX := NVL(INSTR(TEMP,SEP),0);
		IF 
			S_INDEX=0 OR LENGTH(TEMP)=0 THEN
				RES:=NVL(RES,0)+NVL(TEMP,0);
				exit;
		ELSE
			res:=to_number(nvl(res,0))+to_number(substr(temp,0,s_index-1));
			temp := substr(temp,s_index+1,length(temp));
		END IF;
	END LOOP;
	RETURN RES;
	EXCEPTION 
		WHEN others THEN return 0;
END sumstrsplitBySep;

在这里插入图片描述
Return = 6

2.第二种方法:使用正则表达式

WITH TEST AS (SELECT '1|2|3' AS STR FROM DUAL)
SELECT REGEXP_SUBSTR(STR,'[^|]+',1,LEVEL) AS SUMUSE FROM TEST
CONNECT BY LEVEL <= LENGTH(REGEXP_REPLACE(STR,'[^|]',''))+1

在这里插入图片描述

SELECT SUM(SUMUSE) FROM (
WITH TEST AS (SELECT '1|2|3' AS STR FROM DUAL)
SELECT REGEXP_SUBSTR(STR,'[^|]+',1,LEVEL) AS SUMUSE FROM TEST
CONNECT BY LEVEL <= LENGTH(REGEXP_REPLACE(STR,'[^|]',''))+1)

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值