首页 - 数据库 - SQL Server

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

发布时间: 2007-04-19 05:04    作者: 未知    来源: 未知    浏览:    评论


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

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

处理方法表

 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;

TAG

Smile Big Smile Surprise Stick out tongue Wink Sad Tongue Tied Indifferent Crying Embarrassed Cool Angry Angel Devil [8-|] [:#] [:-*] [:^)] [<:o)] [|-)] Yes Beer Left Hug Music Star Time Snail Pizza Automobile Umbrella Computer Storm [mo] [8o|] [^o)] [+o(] [*-)] [8-)] Coffee No Drinks [Z] Right Hug Cake Broken Heart Gift Wilted Flower Movie Dog Idea Sleep Email Travel Paradise
呢称:

加粗 斜体 下划线 链接 图片 代码 邮件地址 引用 列表

最多只能输入100个字符

Tags

SQL 数据库 asp.net C# XML 控件 .NET教程 程序 事件 数据 安全 代码 Server 客户端 验证 数据库专栏 接口 文件 Oracle DataSet 函数 DataGrid 问题 .net return C#语言 JavaScript 服务 IIS 对象 语句 windows 继承 时间 web.config 设计 开发 参数 变量 解决 字符 ADO.net 环境 VB.Net语言 web 异常 工具 服务器 计算 实例 OLEDB Application VB Word WebService insert asp net 安装 记录

精华推荐

更多

精品下载

更多