ORACLE在实现报表的功能是很强大的, 特别在现实的应用中会经常用到人民币大小写转换的问题, 在此我写个函数向大家简单介绍一下, 希望和大家一起探讨, 以便共同进步! 共同发展!
1. 函数DX_MONEY()
CREATE FUNCTION DX_MONEY
(
MONEY IN NUMBER
)
RETURN VARCHAR2 AS V_MONEY VARCHAR2(150);
RV_MONEY0 VARCHAR2(20);
RV_MONEY1 VARCHAR2(4);
RV_MONEY2 VARCHAR2(4);
V_MONEY0 VARCHAR2(20);
V_MONEY1 VARCHAR2(4);
V_MONEY2 VARCHAR2(4);
V_MONEY3 VARCHAR2(4);
V_MONEY4 VARCHAR2(4);
V_MONEY5 VARCHAR2(4);
V_MONEY6 VARCHAR2(4);
V_MONEY7 VARCHAR2(4);
V_MONEY8 VARCHAR2(4);
V_MONEY9 VARCHAR2(4);
V_MONEY10 VARCHAR2(4);
V_MONEY11 VARCHAR2(4);
V_MONEY12 VARCHAR2(4);
RPV_MONEY1 VARCHAR2(4);
RPV_MONEY2 VARCHAR2(4);
PV_MONEY0 VARCHAR2(14);
PV_MONEY1 VARCHAR2(4);
PV_MONEY2 VARCHAR2(4);
PV_MONEY3 VARCHAR2(4);
PV_MONEY4 VARCHAR2(4);
PV_MONEY5 VARCHAR2(4);
PV_MONEY6 VARCHAR2(4);
PV_MONEY7 VARCHAR2(4);
PV_MONEY8 VARCHAR2(4);
PV_MONEY9 VARCHAR2(4);
PV_MONEY10 VARCHAR2(4);
PV_MONEY11 VARCHAR2(4);
PV_MONEY12 VARCHAR2(4);
BEGIN
V_MONEY0:=LTRIM(RTRIM(TO_CHAR(FLOOR(MONEY))));
RV_MONEY0:=LTRIM(RTRIM(TO_CHAR(FLOOR(MONEY*100))));
RV_MONEY1:=SUBSTR(RV_MONEY0,LENGTH(RV_MONEY0),1);
IF LENGTH(RV_MONEY0)>1 THEN
RV_MONEY2:=SUBSTR(RV_MONEY0,LENGTH(RV_MONEY0)-1,1);
ELSE
RV_MONEY2:='0';
END IF;
V_MONEY1:=SUBSTR(V_MONEY0,LENGTH(V_MONEY0),1);
IF LENGTH(V_MONEY0)-1>0 THEN