快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

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

 在业务系统中,不同的客户对小数的处理有不同的方式

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

处理方式表

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;

    
exception
 when OTHERS then RETURN n_Amount;                                            

END Get_Real_Number;


返回类别: 教程
上一教程: 将列更新从一个表传递到另一个表
下一教程: 轻轻松松搞定数据库链接

您可以阅读与"在业务系统中处理小数精度, 四舍五入,全舍弃,全进位的方式"相关的教程:
· 在业务系统中处理小数精度, 四舍五入,全舍弃,全进位的方式
· ACCESS处理重复记录的方式
· SQL SERVER中处理死锁
· SQL Server中处理死锁
· 用脚本缩小数据库日志
    微笑服务 优质保证 索取样品