oracle使用正则表达式REGEXP_SUBSTR提取XML里面的内容

使用extract(XMLTYPE(XML), 'xphat').getstringval()提取XML,长度过长存在报错

ORA-06502: PL/SQL: 数字或值错误 : character string buffer too small

ORA-06512: 在 "SYS.XMLTYPE", line 169

并且存在速度较慢等问题。

正则提取XML,由于这边的XML文本中Name标签,接着的标签即为Value的值,故这样去写。其它的格式需要改正则表达式。

其中

复制代码
([0-9]+(\.[0-9]{1,2})?)

为数字提取。

复制代码
Result :=SUBSTR(re, 1, 4000);
Result :=substrb(Result,1,4000);

为截取4000长度的字符串。

复制代码
create or replace function pyzyyhis6.mc_fn_reg_xml(reg_xml in clob,reg_name in varchar2,reg_re varchar2) return varchar2 is
  Result varchar2(20000); 
  re clob;
begin
--正则提取xml
--reg_xml   clob  传入的xml
--reg_name   varchar2 传入的节点名称
--reg_re varchar2  返回数值的正则规则(数字传"[0-9]+(\.[0-9]{1,2})?"之类的,否则传 [^<>]+)
--作者:ltd
  IF reg_re='1' then  --数字
    re := REGEXP_SUBSTR(reg_xml, '<Name>('||reg_name||')</Name><InnerValue>([0-9]+(\.[0-9]{1,2})?)</InnerValue>',1,1,'c',2);
  ELSIF  reg_re='0' then --正常数值
    re := REGEXP_SUBSTR(reg_xml, '<Name>('||reg_name||')</Name><InnerValue>([^<>]+)</InnerValue>',1,1,'c',2);
  else 
    re := REGEXP_SUBSTR(reg_xml, '<Name>('||reg_name||')</Name><InnerValue>('||reg_re||')</InnerValue>',1,1,'c',2);
  end if;
   Result :=SUBSTR(re, 1, 4000);
   Result :=substrb(Result,1,4000);
  return Result;
end;
相关推荐
GZ_TOGOGO2 小时前
Oracle数据库考试适合哪些人
数据库·oracle·数据库开发·ocp认证·2026年it学习
扑火的小飞蛾4 小时前
【Oracle Database 分区表】之新特性_18c(三)
数据库·oracle
扑火的小飞蛾5 小时前
【Oracle Database 分区表】之间隔分区_11g(一)
数据库·oracle
DarkAthena5 小时前
【GaussDB】分析函数性能优化案例-row_number改写
数据库·sql·oracle·性能优化·gaussdb
Lethehong5 小时前
破局Oracle迁移困局:破局Oracle迁移困局:直面兼容性与成本的隐性痛点
数据库·oracle
枫叶丹45 小时前
Oracle迁移实战:破解兼容性难题与高成本挑战
开发语言·数据库·oracle
心态还需努力呀6 小时前
从 Oracle 到 KingbaseES:一次真实项目的数据库国产化迁移实录
数据库·oracle
sg_knight6 小时前
SQL 中的 IFNULL 函数是什么?
数据库·sql·mysql·oracle·database·关系型数据库·db
她说..7 小时前
FIND_IN_SET()方法
xml·java·spring boot
努力进修7 小时前
国产化替代背景下Oracle与KingbaseES异构迁移技术全解析
数据库·oracle·kingbasees