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

MSSQL
获取MSSQL数据字典的SQL语句
Microsoft Search 服务无法启动 解决办法.
找出所有非xml索引并重新整理的sql
SQL Server提示"选定的用户拥有对象,所以无法除去该用户”
SQL Server"错误 21002: [SQL-DMO]用户 * 已经存在问题解决
删除重复记录,并且剩下一条
select * from sp_who的解决方案
Sql语句与存储过程查询数据的性能测试实现代码
MSSQL 游标使用 心得
SQL 时间类型的模糊查询
mssql 指定字段编号sql语句
sql server中的decimal或者numeric的精度问题
sql 数据库还原图文教程
存储过程解密(破解函数,过程,触发器,视图.仅限于SQLSERVER2000)
MSSQL SERVER中的BETWEEN AND的使用
SQL Server约束增强的两点建议
SQL Server 更改DB的Collation
Oracle 10g各个帐号的访问权限、登录路径、监控状态命令查询等等
SQL Server的复制功能
sql 普通行列转换

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 90 ::
收藏到网摘: 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