zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    C++解析-外传篇(3):动态内存申请的结果
    C++解析-外传篇(2):函数的异常规格说明
    C++解析-外传篇(1):异常处理深度解析
    C++解析(31):自定义内存管理(完)
    Fisherfaces 算法的具体实现源码
    Philipp Wagner
    人脸识别中截取面部的实现方法
    OpenCV Haar AdaBoost源码改进据说是比EMCV快6倍
    win10系统下载地址
    人脸识别中的检测(在Opencv中加入了QT)
  • 原文地址:https://www.cnblogs.com/ybtools/p/3177422.html
Copyright © 2011-2022 走看看