oracle 数字大写转换,oracle数据库使用游标实现大写数字转换成小写数字

项目遇到需求,需要将大写数字转换成小写。代码如下:declare

t_zl varchar2(100);

t_ts varchar2(100);

t_l number;

hh varchar2(100);

xx varchar2(100);

type TIArray is table of varchar2(100);

type TCArray is table of varchar2(100);

A TIArray;

B TCArray;

cursor c is select zl,tstybm from  fc_h_qsdc2;

begin

A:=TIArray(‘四十七‘,‘四十六‘,‘四十五‘,‘四十四‘,‘四十三‘,‘四十二‘,‘四十一‘,‘三十九‘,‘三十八‘,‘三十七‘,

‘三十六‘,‘三十五‘,‘三十四‘,‘三十三‘,‘三十二‘,‘三十一‘,‘二十九‘,‘二十八‘,‘二十七‘,‘二十六‘,‘二十五‘,‘二十四‘,‘二十三‘,

‘二十二‘,‘二十一‘,‘四十‘,‘三十‘,‘二十‘,‘十九‘,‘十八‘,‘十七‘,‘十六‘,‘十五‘,‘十四‘,‘十三‘,‘十二‘,‘十一‘,‘十‘,‘九‘,‘八‘,‘七‘,‘六‘,‘五‘,‘四‘,‘三‘,‘二‘,‘一‘);

B:=TCArray(‘47‘,‘46‘,‘45‘,‘44‘,‘43‘,‘42‘,‘41‘,‘39‘,‘38‘,‘37‘,‘36‘,‘35‘,‘34‘,‘33‘,‘32‘,‘31‘,‘29‘,‘28‘,‘27‘,‘26‘,‘25‘,‘24‘,‘23‘,‘22‘,‘21‘,‘40‘,‘30‘,‘20‘,‘19‘,‘18‘,‘17‘,‘16‘,‘15‘,‘14‘,‘13‘,‘12‘,‘11‘,‘10‘,‘9‘

,‘8‘,‘7‘,‘6‘,‘5‘,‘4‘,‘3‘,‘2‘,‘1‘);

open c;

loop

fetch c into t_zl,t_ts;

exit when c%notfound;

for i in 1..47 loop

select instr(t_zl,A(i)) into xx from dual;

if (xx>0 and length(A(i))=3) then

hh:=substr(t_zl,1,xx-1)||B(i)||substr(t_zl,xx+3);

elsif(xx>0 and length(A(i))=2) then

hh:=substr(t_zl,1,xx-1)||B(i)||substr(t_zl,xx+2);

elsif(xx>0 and length(A(i))=1) then

hh:=substr(t_zl,1,xx-1)||B(i)||substr(t_zl,xx+1);

else

hh:=t_zl;

end if;

t_zl:=hh;

end loop;

update fc_h_qsdc2 set zl=t_zl where tstybm=t_ts;

end loop;

close c;

end;

注:实现关键点,利用(type type_name is table of{column_type|variable_name%type|table_name.column_name%type|table_name%rowtype}[not null] index by{pls_integer|binary_tnteger|varchar2(v_size)})该类型和数组类似,利用键值查找对应的值。

2016-05-11

本文出自 “MST” 博客,请务必保留此出处http://wolihaito.blog.51cto.com/1904662/1772865

oracle数据库使用游标实现大写数字转换成小写数字

标签:oracle大写数字转换成小写

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉 本文系统来源:http://wolihaito.blog.51cto.com/1904662/1772865

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值