程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> 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; 

結果:

玖仟三佰貳拾肆億零貳佰玖拾三萬肆仟零貳拾肆圓貳角整

測試通過

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved