在业务系统中处理小数精度, 四舍五入,全舍弃,全进位的方法

靠自己的努力洋

靠自己的努力洋

2016-01-29 16:51

在业务系统中处理小数精度, 四舍五入,全舍弃,全进位的方法,在业务系统中处理小数精度, 四舍五入,全舍弃,全进位的方法
 在业务系统中,不同的客户对小数的处理有不同的方法

通过在设置保留的小数位数,以及小数位数以后的尾数的处理方法,可以灵活的满足客户要求

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/sqlserver/)

处理方法表

ID NUMBER(1)    ,                                                       --设置ID

AMOUNTDOT      NUMBER(4,2) DEFAULT 0.01,  --金额精确度 1: 精确到元  0.1:精确到角  0.01:精确到分ROUNDING       NUMBER(1) ,                                  --舍入分界  -- 9: 全舍  0: 全入  4:四舍5入   

建立ORACLE函数,传入设置ID,传入金额,返回处理过的金额

存储过程实现代码如下

create or replace function Get_Real_Number (  --根据处理方法ID,取得处理后的金额-计算的金额
            ID IN NUMBER, -- 处理方法ID
            n_Amount IN NUMBER)    
  -----------------------------------------------------------------------
  --  用  途   自定义数据精度处理。
  --  创建者  :Andrew
  -----------------------------------------------------------------------
  --  修改记录列表:(按日期的先后顺序逆序排列)
  --  修改时间     修改人      实现的功能说明
   -- 9 全舍  0 全入  4四舍5入 
  -----------------------------------------------------------------------
return NUMBER-- 返回的金额
IS
       v_amountdot VARCHAR2(5);      --小数位数字符
       v_keep      NUMBER ;          --保留的小数位数
       v_rounding  NUMBER ;        --舍入分界
       v_Amount NUMBER:=0 ;         --返回的金额
BEGIN

     SELECT  amountdot,  nvl(rounding,0) INTO v_amountdot,v_rounding FROM  处理方法表
             WHERE id = SALE_PLACE_ID;
     v_keep := Length(v_amountdot) -  instr(v_amountdot,'.') ;  --要保留的小数位数
     IF v_rounding = 9 THEN   --处理全舍弃
        v_Amount := trunc(n_Amount,v_keep);
     END IF;
    
     IF v_rounding = 4 THEN    --处理四舍五入
        v_Amount := round(n_Amount,v_keep);
     END IF;
    
     IF v_rounding = 0 THEN  --处理全进位
            v_Amount := trunc(n_Amount,v_keep);   --小数为数刚好等于要求保留的数
           IF v_Amount < n_Amount THEN   --如果截取后的数与原来的数字不同,进1
           v_Amount := v_Amount + to_number(v_amountdot);
     END IF;

     RETURN v_Amount;

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/sqlserver/)

   &nb

展开更多 50%)
分享

猜你喜欢

在业务系统中处理小数精度, 四舍五入,全舍弃,全进位的方法

SQLServer
在业务系统中处理小数精度, 四舍五入,全舍弃,全进位的方法

Excel怎样取消四舍五入

excel
Excel怎样取消四舍五入

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

excel四舍五入函数怎么用

excel
excel四舍五入函数怎么用

Excel作假:真正的实现四舍五入

办公软件
Excel作假:真正的实现四舍五入

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

Excel教程:如何取消四舍五入

excel
Excel教程:如何取消四舍五入

巧用WPS移动版组合函数四舍五入保留两位小数

电脑入门
巧用WPS移动版组合函数四舍五入保留两位小数

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

利用数据库复制技术 实现数据同步更新

利用数据库复制技术 实现数据同步更新

《我叫MT》竞技场胜率较高的白卡阵容推荐

《我叫MT》竞技场胜率较高的白卡阵容推荐
下拉加载更多内容 ↓