判断A字符串在B字符串中连续出现的最大次数

create or replace function FUN_INSTR_CNT(in_str   varchar2,
                                         in_instr varchar2) return number as
  i      number := 1;
  v_lsx  varchar2(4000) default '';
  vv_lsx varchar2(4000) default '';
  v_len  number := 1;
begin
  if length(in_instr) >= 1 then
    v_len := length(in_str);
    while i <= v_len loop
      v_lsx := v_lsx || in_instr;
      i     := i + 1;
    end loop;
  
    i := 1;
    while i <= v_len loop
      vv_lsx := substr(v_lsx, 1, v_len - i + 1);
    
      if instr(in_str, vv_lsx) >= 1 and length(vv_lsx) >= length(in_instr) then
        return length(vv_lsx) / length(in_instr);
      end if;
      i := i + 1;
    end loop;
  end if;
  return 0;
end;
/

执行结果

 
SQL> select FUN_INSTR_CNT('aafffbbfffffd','f'),FUN_INSTR_CNT('0000','1'),FUN_INSTR_CNT('101010','11'),FUN_INSTR_CNT('101010','1'),FUN_INSTR_CNT('101010','1'),FUN_INSTR_CNT('10101011','1') from dual;
;
 
FUN_INSTR_CNT('AAFFFBBFFFFFD', FUN_INSTR_CNT('0000','1') FUN_INSTR_CNT('101010','11') FUN_INSTR_CNT('101010','1') FUN_INSTR_CNT('101010','1') FUN_INSTR_CNT('10101011','1')
------------------------------ ------------------------- ---------------------------- --------------------------- --------------------------- -----------------------------
                             5                         0                            0                           1                           1                             2
 
SQL> 
SQL> 



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

-无-为-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值