详解Oracle中数字与大写交换

数据库 Oracle
在这里我们将介绍Oracle中数字与大写交换,希望能对大家了解Oracle一些功能有所帮助。

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

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

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

代码:

  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.cnblogs.com/Ira_Young/archive/2009/11/11/1601168.html

责任编辑:彭凡 来源: 博客园
相关推荐

2010-04-16 09:37:51

Oracle

2018-12-18 09:40:27

LinuxCtrl命令

2019-04-18 15:00:36

2009-11-04 10:50:48

Oracle创建用户授

2010-04-02 09:07:26

Oracle sqlp

2009-04-29 16:05:23

Oracle连接输出SQL

2010-03-29 13:19:10

OracleMulti

2010-04-02 17:11:45

Oracle数据库

2010-02-01 10:10:41

Oracle数据库优化

2010-03-16 17:14:19

Python字符串

2011-08-18 13:44:42

Oracle悲观锁乐观锁

2010-11-15 11:58:02

Oracle物理结构

2011-05-19 13:25:14

Oracle数据库

2010-11-18 11:08:30

oracle授权语句

2013-09-24 15:24:08

Oracle营销云

2009-10-27 16:36:07

Oracle如何解锁

2010-04-08 10:17:37

Oracle体系结构

2011-08-03 13:11:10

Oracle数据库序列

2009-05-13 10:28:30

OracleDUAL数据库

2011-08-22 15:47:27

Oracle临时表存储过程
点赞
收藏

51CTO技术栈公众号