ORACLE 数字转换人民币大写

 

 

示例.

 

数字                    :183066999230.68

人民币大写        :壹仟捌佰参拾亿陆仟陆佰玖拾玖万玖仟贰佰参拾圆陆角捌分

 

数字                    :999900000000

人民币大写        :玖仟玖佰玖拾玖亿圆整

 

 

 

Step 1.  Create Lookups:   CUX_CNY_DICTIONARY

(N) Application Developer > Application > Lookups > Application Object Library

 

 

Application Object Library Lookups

Type

CUX_CNY_DICTIONARY

Access Level

 

l    

User

 

Extensible

 

System

Meaning

CUX_CNY_DICTIONARY

Application

Application Object Library

Description

CNY character translation

 

Code

Meaning

Description

Tag

From

To

Enabled

[   ]

0

 

 

 

 

*

 

1

 

 

 

 

*

 

2

 

 

 

 

*

 

3

 

 

 

 

*

 

4

 

 

 

 

*

 

5

 

 

 

 

*

 

6

 

 

 

 

*

 

7

 

 

 

 

*

 

8

 

 

 

 

*

 

9

 

 

 

 

*

 

Q

 

 

 

 

*

 

B

 

 

 

 

*

 

S

 

 

 

 

*

 

Y

亿

 

 

 

 

*

 

W

 

 

 

 

*

 

U

 

 

 

 

*

 

Z

 

 

 

 

*

 

J

 

 

 

 

*

 

F

 

 

 

 

*

 

 

 

Step 2.  Create Function:       CUX_CONVERT_CNY

create or replace function cux_convert_cny(num in number) return varchar2

is

l_receive_number   number(14,2);

l_number   varchar2(100);

l_num_length  number;

l_unit  varchar2(100) := 'QBSGYQBSGWQBSG.JF';

l_cny  varchar2(200);

l_trans_cny  varchar2(200);

 

function translater(transNum in varchar2) return varchar2

is

l_meaning  varchar2(80);

begin

select flv.meaning

  into l_meaning

  from fnd_lookup_values_vl flv

 where     1 = 1

       and flv.enabled_flag = 'Y'

       and sysdate between nvl (flv.start_date_active, sysdate)

                       and nvl (flv.end_date_active, sysdate + 1)      

       and flv.lookup_code = transNum

       and flv.lookup_type = 'CUX_CNY_DICTIONARY'

       and flv.view_application_id = 0

       and flv.security_group_id = 0;

 

return l_meaning;      

end translater;

 

begin

 

--checking input number throw exception

select decode(num, 0, 'x', num) into l_receive_number from dual;

l_number := trim(to_char(l_receive_number, '9999,9999,9999.99'));

l_num_length := length(l_number);

 

--linking number and unit

for numIndex in 1..l_num_length loop

    l_cny := l_cny || (substr(l_number, numIndex, 1) || substr(l_unit, -(l_num_length-numIndex+1), 1));

end loop;

 

--replace symbol

select regexp_replace(l_cny, ',|\.', '') into l_cny from dual;

--insert UZ to 0J0F

select regexp_replace(l_cny, '(0J0F)', 'UZ') into l_cny from dual;

--insert U to xJxF

select regexp_replace(l_cny, '([0-9]J[0-9]F)', 'U\1') into l_cny from dual;

--replace more zero to blank

select regexp_replace(l_cny, '(0Q0B0S0GW)|(0Q0B0S0G)|(0B0S0G)|(0S0G)|(0G)|(G)|(0J)|(0F)', '') into l_cny from dual;

--replace more zero to zero

select regexp_replace(l_cny, '(0Q0B0S)|(0Q0B)|(0Q)|(0B)|(0S)', '0') into l_cny from dual;

 

--translation

for transIndex in 1..length(l_cny) loop

    l_trans_cny := l_trans_cny || translater(substr(l_cny,transIndex, 1));

end loop;

 

return l_trans_cny;

exception when others

then

fnd_file.put_line (fnd_file.output, sqlcode);

fnd_file.put_line (fnd_file.output, sqlerrm);

end;

 

 

 

 

Step 3.  Apply Function: CUX_CONVERT_CNY

 

select cux_convert_cny (183066999230.68) cny from dual;

 

select cux_convert_cny (999900000000) cny from dual;

 

 

 

 

 

 

 

 

 

 

 

 

 

Author

若愚

Creation Date

November 4, 2014

Last Updated

November 4, 2014

Version

V1411.2

 

ORACLE数字转换人民币大写的更多相关文章

  1. 数字转人民币大写(SQL SERVER)

    --数字转人民币大写NumToRMB ---新建方法create  FUNCTION dbo.NumToRMB (@num numeric(14,5))   RETURNS varchar(100) ...

  2. sql 数字转人民币大写函数(两种方法)

    ,)) returns @rmb table( 亿 ) ,仟万 ) ,佰万 ) ,拾万 ) ,万 ) ,仟 ) ,佰 ) ,拾 ) ,元 ) ,角 ) ,分 )) as begin insert in ...

  3. js将数字转换成大写的人民币表达式

    function changeNumMoneyToChinese(money) { var cnNums = new Array("零", "壹", " ...

  4. C# 数字转换成大写

    /// <summary> /// 数字转大写 /// </summary> /// <param name="Num">数字</para ...

  5. 【PHP】金额数字转换成大写形式

    <?php /*将数字金额转成大写*/ function num_to_upper($num) { $d = array('零','壹','贰','叁','肆','伍','陆','柒','捌', ...

  6. 实现数字转换RMB大写~

    实现的功能是将数字“673”转换成“陆佰柒拾叁”    “3681”转换成“叁仟陆佰捌拾壹”     “8007”转换成“捌仟零柒” 主要使用了数组和循环来实现 代码雏形 package com.te ...

  7. PHP实现金额数字转换成大写函数

    <?php header("Content-Type:text/html;charset=utf-8"); function num_to_upper($num) { $d ...

  8. 一个用php写的人民币数字转人民币大写的函数

      function num2rmb ($num) {     $c1 = "零壹贰叁肆伍陆柒捌玖";     $c2 = "分角元拾佰仟万拾佰仟亿";     ...

  9. php数字转人民币金额大写

    numToRmb.php <?php header("content-type:text/html;charset=utf-8"); function numToRmb($n ...

随机推荐

  1. Java NIO 选择器(Selector)的内部实现(poll epoll)

    http://blog.csdn.net/hsuxu/article/details/9876983 之前强调这么多关于linux内核的poll及epoll,无非是想让大家先有个认识: Java NI ...

  2. JS实现rgb与16进制颜色相互转换

    1.rgb转16进制 function to16 (a) {//RGB(204,204,024) //十六进制颜色值的正则表达式 var reg = /^#([0-9a-fA-f]{3}|[0-9a- ...

  3. UVA 11462 Age Sort(计数排序法 优化输入输出)

    Age Sort You are given the ages (in years) of all people of a country with at least 1 year of age. Y ...

  4. VS中使用sqlite静态连接

    说明 最近写的文章有些多,懒得打字了,就直接上文章.这里说明一下,我说的是VS,不是指定的哪一个VS版本.先下载官方的源文件:sqlite-amalgamation-3071502.zip 下载下来的 ...

  5. 处理safari缓存的办法

    window.onpageshow = function(event) {        if (event.persisted) {             alert("From bac ...

  6. MongoDB笔记(一)MongoDB概述和安装

    概述 关键词:关系数据库.非关系数据库 关系数据库: 关系数据库,是建立在关系数据库模型基础上的数据库,借助于集合代数等概念和方法来处理数据库中的数据.目前主流的关系数据库有oracle.SQL.ac ...

  7. shell通过ftp实现上传/下载文件

    直接代码,shell文件名为testFtptool.sh: #!/bin/bash ########################################################## ...

  8. javascript 事件流及应用

    当页面元素触发事件的时候,该元素的容器以及整个页面都会按照特定顺序发生该元素的触发 事件,事件传播的顺序叫做事件流 1.事件流的分类: A.冒泡型事件(所有浏览器都支持)   由明确的事件源到最不确定 ...

  9. markdown与textile之间互相转换

    markdown与textile之间互相转换 redmine中默认使用的是textile那么从别的地方复制过来的markdown格式的内容需要进行转换 找到一款工具叫做pandoc http://jo ...

  10. rgba兼容IE系列

    在容器里面如果用到opacity或者filter:opacity里面的内容也会被滤镜化 如果不想里面的内容也被滤镜化我们可以用rgba来处理或者用透明的背景图片. 兼容ie的rgba的写法 backg ...