oracle 如何截取一个字符串直到后面全是0为止

2025-03-23 18:09:13
推荐回答(2个)
回答1:

存储过程做吧。

录入数据

create table test
(id varchar2(100));


insert into test values ('10133200000000');
insert into test values ('51302011000000');
insert into test values ('35900000000000');
commit;

执行代码:

declare
  v_str        varchar2(100);
  v_str1       varchar2(100);
  v_id_reverse varchar2(100);
  v_s          int;
  cursor c_str is
    select id from test;
begin
  open c_str;
  loop
    fetch c_str
      into v_str;
    exit when c_str%notfound;
    select reverse(v_str) into v_id_reverse from dual;
    v_s := 1;
    loop
      select substr(v_id_reverse, v_s, 1) into v_str from dual;
      if v_str = 0 then
        v_s := v_s + 1;
      else
        select reverse(substr(v_id_reverse,
                              v_s,
                              length(v_id_reverse) - v_s + 1))
          into v_str1
          from dual;
        exit;
      end if;
    end loop;
    dbms_output.put_line(v_str1);
  end loop;
  close c_str;
end;

执行结果:

回答2:

select reverse(to_char(to_number(reverse('10133200000000')))) from dual;
也可以用语句来处理的(全数字)
第一步:将字符串反向排序
第二步:转换成数值类型(这一步可以去掉0啦)
第三步:转换成字符串类型(反向函数不支持数值类型)
第四步:将字符串反向排序(再转回来)