详解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