SQL循环拆分

本文介绍了一个使用 Oracle SQL 的示例程序,该程序通过循环遍历和字符串操作功能来解析并插入带有分号分隔符的错误原因字段到另一个表中。此过程能够处理空字符串和多个分号的情况,并将每一条错误信息作为单独的记录存储。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

declare
v_num number :=1;
v_num1 number :=0;
begin
   for jieguo in(
     select d.transcode ,d.errorreason from  HEALTH22PERROR  d  where  d.transcode like '9025%'
     )
     loop
       v_num1 :=0;
       loop
         v_num1 :=v_num1+1;
         v_num  :=instr(jieguo.errorreason,';',1,v_num1);
        
       if v_num =0 and v_num1=1 then  insert into health21perror values(jieguo.transcode,jieguo.errorreason);
       elsif v_num=0 and v_num1>1 then
       insert into health21perror
       values(jieguo.transcode,
       substr(jieguo.errorreason,instr (jieguo.errorreason,';',1,v_num1-1)+1,
       length (jieguo.errorreason)-instr(jieguo.errorreason,';',v_num1)));
       elsif v_num1>0 and v_num1=1 then
       insert into health21perror  values(jieguo.transcode,substr(jieguo.errorreason,1,v_num-1));
       
       elsif v_num>0 and v_num1>1 then
       insert into health21perror
       values (jieguo.transcode,
        substr(jieguo.errorreason,instr(jieguo.errorreason,';',1,v_num1-1)+1,
       v_num-1-instr (jieguo.errorreason,';',1,v_num1-1)));
       end if;
       exit when v_num=0;
       end loop;
       end loop;
       commit;
       end;
   --select errorreason ,count(transcode) from health21perror group by  errorreason
     
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值