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

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/242629.html<

(0)
运维的头像运维
上一篇2025-04-24 21:36
下一篇 2025-04-24 21:38

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注