• ORACLE 小写金额转大写金额


    Create Or Replace Function Money2Chinese(Money In Number) Return Varchar2 Is
      strYuan       Varchar2(150);
      strYuanFen    Varchar2(152);
      numLenYuan    Number;
      numLenYuanFen Number;
      strRstYuan    Varchar2(600);
      strRstFen     Varchar2(200);
      strRst        Varchar2(800);
      Type typeTabMapping Is Table Of Varchar2(2) Index By Binary_Integer;
      tabNumMapping  typeTabMapping;
      tabUnitMapping typeTabMapping;
      numUnitIndex   Number;
      i              Number;
      j              Number;
      charCurrentNum Char(1);
    Begin
      If Money Is Null Then
        Return Null;
      End If;
      strYuan := TO_CHAR(FLOOR(Money));
      If strYuan = '0' Then
        numLenYuan := 0;
        strYuanFen := lpad(TO_CHAR(FLOOR(Money * 100)), 2, '0');
      Else
        numLenYuan := length(strYuan);
        strYuanFen := TO_CHAR(FLOOR(Money * 100));
      End If;
      If strYuanFen = '0' Then
        numLenYuanFen := 0;
      Else
        numLenYuanFen := length(strYuanFen);
      End If;
      If numLenYuan = 0 Or numLenYuanFen = 0 Then
        strRst := '零圆整';
        Return strRst;
      End If;
      tabNumMapping(0) := '';
      tabNumMapping(1) := '';
      tabNumMapping(2) := '';
      tabNumMapping(3) := '';
      tabNumMapping(4) := '';
      tabNumMapping(5) := '';
      tabNumMapping(6) := '';
      tabNumMapping(7) := '';
      tabNumMapping(8) := '';
      tabNumMapping(9) := '';
      tabUnitMapping(-2) := '';
      tabUnitMapping(-1) := '';
      tabUnitMapping(1) := '';
      tabUnitMapping(2) := '';
      tabUnitMapping(3) := '';
      tabUnitMapping(4) := '';
      tabUnitMapping(5) := '';
      tabUnitMapping(6) := '';
      tabUnitMapping(7) := '';
      tabUnitMapping(8) := '';
      tabUnitMapping(9) := '亿';
      For i In 1 .. numLenYuan Loop
        j            := numLenYuan - i + 1;
        numUnitIndex := Mod(i, 8);
        If numUnitIndex = 0 Then
          numUnitIndex := 8;
        End If;
        If numUnitIndex = 1 And i > 1 Then
          strRstYuan := tabUnitMapping(9) || strRstYuan;
        End If;
        charCurrentNum := substr(strYuan, j, 1);
        If charCurrentNum <> 0 Then
          strRstYuan := tabNumMapping(charCurrentNum) ||
                        tabUnitMapping(numUnitIndex) || strRstYuan;
        Else
          If (i = 1 Or i = 5) Then
            If substr(strYuan, j - 3, 4) <> '0000' Then
              strRstYuan := tabUnitMapping(numUnitIndex) || strRstYuan;
            End If;
          Else
            If substr(strYuan, j + 1, 1) <> '0' Then
              strRstYuan := tabNumMapping(charCurrentNum) || strRstYuan;
            End If;
          End If;
        End If;
      End Loop;
      For i In -2 .. -1 Loop
        j              := numLenYuan - i;
        charCurrentNum := substr(strYuanFen, j, 1);
        If charCurrentNum <> '0' Then
          strRstFen := tabNumMapping(charCurrentNum) || tabUnitMapping(i) ||
                       strRstFen;
        End If;
      End Loop;
      If strRstYuan Is Not Null Then
        strRstYuan := strRstYuan || '';
      End If;
      If strRstFen Is Null Then
        strRstYuan := strRstYuan || '';
      Elsif length(strRstFen) = 2 And substr(strRstFen, 2) = '' Then
        strRstFen := strRstFen || '';
      End If;
      strRst := strRstYuan || strRstFen;
      --strRst := Replace(strRst, '亿零', '亿');
      --strRst := Replace(strRst, '万零', '');
      Return strRst;
    End Money2Chinese;

    测试SQL如下:

    Select Money2Chinese(0932402934024.213) From dual;

    结果:

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

    测试通过

    转自:http://www.cnblogs.com/Ira_Young/archive/2009/11/11/1601168.html

  • 相关阅读:
    【UML九种图系列】之用例图
    数据结构之后缀数组
    Web Service实例——天气预报
    庞果网 合法字符串
    web 版发送邮件-已删除
    C语言实现双向链表删除节点、插入节点、双向输出等操作
    [置顶] String StringBuffer StringBuilder的区别剖析
    N!末尾有多少个零
    细说业务逻辑 -- 丢失的业务逻辑层
    你真的了解分层架构吗?——写给被PetShop"毒害"的朋友们
  • 原文地址:https://www.cnblogs.com/ybtools/p/3177422.html
Copyright © 2020-2023  润新知