当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 在业务系统中处理小数精度, 四舍五入,全舍弃,全进位的方法

MSSQL
SQL Server中删除重复数据的几个方法
SQL Server 基础概念集
SQL Server导入导出
SQL SERVER实用技巧
sql server 常用函数
如何维护SQL Server的“交易日志”
SQL Server数据备份处理过程探讨
JSP中tomcat的SQL Server2000数据库连接池的配置
SQL Server服务器安装剖析
SQL Server 2005数据加密技术应用研究
SQL Server数据库的备份和恢复措施
SQL Server 2005性能测试实践
Jboss下MS SQL Server配置指导
Oracle和SQL Server 追求完美还是讲求实用
SQL Server服务器安装剖析
SQL Server:Oracle与SQL Server事务处理的比较
SQL Server:利用配置文件实现SQL Server与Oralce访问类的转换
SQL Server:测试SQL Server业务规则链接方法
SQL Server :SQL Server 2008高可用性解决方案优劣分析
SQLServer:数据库恢复

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 50 ::
收藏到网摘: n/a

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

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

处理方法表

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;

   &nb