存储过程做吧。
录入数据
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;
执行结果:
select reverse(to_char(to_number(reverse('10133200000000')))) from dual;
也可以用语句来处理的(全数字)
第一步:将字符串反向排序
第二步:转换成数值类型(这一步可以去掉0啦)
第三步:转换成字符串类型(反向函数不支持数值类型)
第四步:将字符串反向排序(再转回来)