详解Oracle中数字与大写交换

对于数字大小写的转换,也是有一定中国特色的东西。但是在账务报表中,我们还是需要有这样的功能的。今天写了一个将数字金额转化为大写的函数。

创新互联公司自2013年起,先为宁县等服务建站,宁县等地企业,进行企业商务咨询服务。为宁县企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

功能:将任意长度的数字金额转化为大写。***位为圆或角时,后面加“整”;为“分”时不加“整”。

说明:小数点后保留两位。超过两位的部分被截断。

代码:

 
 
  1. PL/SQL 代码  
  2. Create Or Replace Function Money2Chinese(Money In Number) Return Varchar2 Is 
  3.   strYuan       Varchar2(150);  
  4.   strYuanFen    Varchar2(152);  
  5.   numLenYuan    Number;  
  6.   numLenYuanFen Number;  
  7.   strRstYuan    Varchar2(600);  
  8.   strRstFen     Varchar2(200);  
  9.   strRst        Varchar2(800);  
  10.   Type typeTabMapping Is Table Of Varchar2(2) Index By Binary_Integer;  
  11.   tabNumMapping  typeTabMapping;  
  12.   tabUnitMapping typeTabMapping;  
  13.   numUnitIndex   Number;  
  14.   i              Number;  
  15.   j              Number;  
  16.   charCurrentNum Char(1);  
  17. Begin 
  18.   If Money Is Null Then 
  19.     Return Null;  
  20.   End If;  
  21.   strYuan := TO_CHAR(FLOOR(Money));  
  22.   If strYuan = '0' Then 
  23.     numLenYuan := 0;  
  24.     strYuanFen := lpad(TO_CHAR(FLOOR(Money * 100)), 2, '0');  
  25.   Else 
  26.     numLenYuan := length(strYuan);  
  27.     strYuanFen := TO_CHAR(FLOOR(Money * 100));  
  28.   End If;  
  29.   If strYuanFen = '0' Then 
  30.     numLenYuanFen := 0;  
  31.   Else 
  32.     numLenYuanFen := length(strYuanFen);  
  33.   End If;  
  34.   If numLenYuan = 0 Or numLenYuanFen = 0 Then 
  35.     strRst := '零圆整';  
  36.     Return strRst;  
  37.   End If;  
  38.   tabNumMapping(0) := '零';  
  39.   tabNumMapping(1) := '壹';  
  40.   tabNumMapping(2) := '贰';  
  41.   tabNumMapping(3) := '叁';  
  42.   tabNumMapping(4) := '肆';  
  43.   tabNumMapping(5) := '伍';  
  44.   tabNumMapping(6) := '陆';  
  45.   tabNumMapping(7) := '柒';  
  46.   tabNumMapping(8) := '捌';  
  47.   tabNumMapping(9) := '玖';  
  48.   tabUnitMapping(-2) := '分';  
  49.   tabUnitMapping(-1) := '角';  
  50.   tabUnitMapping(1) := '';  
  51.   tabUnitMapping(2) := '拾';  
  52.   tabUnitMapping(3) := '佰';  
  53.   tabUnitMapping(4) := '仟';  
  54.   tabUnitMapping(5) := '万';  
  55.   tabUnitMapping(6) := '拾';  
  56.   tabUnitMapping(7) := '佰';  
  57.   tabUnitMapping(8) := '仟';  
  58.   tabUnitMapping(9) := '亿';  
  59.   For i In 1 .. numLenYuan Loop  
  60.     j            := numLenYuan - i + 1;  
  61.     numUnitIndex := Mod(i, 8);  
  62.     If numUnitIndex = 0 Then 
  63.       numUnitIndex := 8;  
  64.     End If;  
  65.     If numUnitIndex = 1 And i > 1 Then 
  66.       strRstYuan := tabUnitMapping(9) || strRstYuan;  
  67.     End If;  
  68.     charCurrentNum := substr(strYuan, j, 1);  
  69.     If charCurrentNum <> 0 Then 
  70.       strRstYuan := tabNumMapping(charCurrentNum) ||  
  71.                     tabUnitMapping(numUnitIndex) || strRstYuan;  
  72.     Else 
  73.       If (i = 1 Or i = 5) Then 
  74.         If substr(strYuan, j - 3, 4) <> '0000' Then 
  75.           strRstYuan := tabUnitMapping(numUnitIndex) || strRstYuan;  
  76.         End If;  
  77.       Else 
  78.         If substr(strYuan, j + 1, 1) <> '0' Then 
  79.           strRstYuan := tabNumMapping(charCurrentNum) || strRstYuan;  
  80.         End If;  
  81.       End If;  
  82.     End If;  
  83.   End Loop;  
  84.   For i In -2 .. -1 Loop  
  85.     j              := numLenYuan - i;  
  86.     charCurrentNum := substr(strYuanFen, j, 1);  
  87.     If charCurrentNum <> '0' Then 
  88.       strRstFen := tabNumMapping(charCurrentNum) || tabUnitMapping(i) ||  
  89.                    strRstFen;  
  90.     End If;  
  91.   End Loop;  
  92.   If strRstYuan Is Not Null Then 
  93.     strRstYuan := strRstYuan || '圆';  
  94.   End If;  
  95.   If strRstFen Is Null Then 
  96.     strRstYuan := strRstYuan || '整';  
  97.   Elsif length(strRstFen) = 2 And substr(strRstFen, 2) = '角' Then 
  98.     strRstFen := strRstFen || '整';  
  99.   End If;  
  100.   strRst := strRstYuan || strRstFen;  
  101.   --strRst := Replace(strRst, '亿零', '亿');  
  102.   --strRst := Replace(strRst, '万零', '万');  
  103.   Return strRst;  
  104. End Money2Chinese; 

测试SQL如下:

 
 
  1. Select Money2Chinese(0932402934024.213) From dual; 

结果:

玖仟叁佰贰拾肆亿零贰佰玖拾叁万肆仟零贰拾肆圆贰角整

测试通过

当前名称:详解Oracle中数字与大写交换
新闻来源:http://www.mswzjz.cn/qtweb/news13/250463.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能