yangsheng0915 2010-05-14 11:45
浏览 772
已采纳

Oracle 字符串分割函数返回分割后的数组长度

请教大家个oracle 字符串分割函数并且该函数返回数组长度

现在我的数据库某个字段存值如下: '1/2/3' 如何编写一个函数能根据'/' 分割返回一个数组长度3

类似java中的split方法
我这样写现在不行
CREATE OR REPLACE FUNCTION split (sourcestr IN VARCHAR2, regstr IN VARCHAR2)

RETURN int

IS

i INT := 0;

sourcestr2 varchar2(50);
j int:=0;

BEGIN

j:=length(regstr);
sourcestr2 := sourcestr;
while j>0 LOOP

     i := instr(sourcestr2, regstr);   

    IF i > 0   THEN 
         i:=i+1; 
         sourcestr2 := substr(sourcestr2,i+j);

    END IF;       
END LOOP;   

RETURN i;   

END split;

  • 写回答

1条回答 默认 最新

  • weixin_42518082 2010-05-14 12:22
    关注

    [code="sql"]
    FUNCTION splitArrayLength (v_source IN VARCHAR2, v_delimiter IN VARCHAR2)
    RETURN INT IS
    j INT := 0;
    i INT := 1;
    len INT := 0;
    delim_len INT := 0;
    cnt INT := 0;
    BEGIN
    len := length(v_source);
    delim_len := length(v_delimiter);
    WHILE j < len LOOP
    j := instr(v_source, v_delimiter, i);
    IF j = 0 THEN
    j := len;
    cnt := cnt+1;
    IF i >= len THEN
    EXIT;
    END IF;
    ELSE
    i := j + delim_len;
    cnt := cnt+1;
    END IF;
    END LOOP;
    RETURN cnt;
    END splitArrayLength;
    [/code]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题
  • ¥30 python代码,帮调试
  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊