“四舍五入”是我们最早接触的数学概念之一。我们日常开发系统中,数字取整也是我们最常接触的一种需求样式。在财务相关系统中,四舍五入的算法有时候对系统用户造成巨大的影响。

在Oracle SQL中,提供了四种数字取整函数。从名称上,他们都是在取整,但是具体算法有所不同。在本篇里面,我们进行一下详细的分析。

1、环境介绍和准备

我们依然选择Oracle 11gR2版本进行测试。

SQL> select * from v$version;

BANNER

--------------------------------------------------------------------------

Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production

PL/SQL Release 11.2.0.1.0 - Production

CORE11.2.0.1.0Production

不同种类数据进行测试。

SQL> create table t (id number);

Table created

SQL> select * from t;

ID

----------

0

1

1.3

1.5

1.8

-1

-1.3

-1.5

-1.8

9 rows selected

2、四种基本取整函数

Oracle中的四种有取证功能函数为:ceil、floor、trunc和round,每一个都有不同的含义和特点,适合不同的场景。

Ceil的原始含义是说:返回比当前值大的第一个整数。这里要注意“大”的概念,最简单的理解就是我们数学上的数轴。Ceil就是返回当前值在数轴往右第一个整数值。

SQL> select id, ceil(id) from t;

IDCEIL(ID)

---------- ----------

00

11

1.32

1.52

1.82

-1-1

-1.3-1

-1.5-1

-1.8-1

9 rows selected

这里主要注意负数的ceil结果,和我们直观的想法有一些差异。而且ceil并没有进行四舍五入。

Floor与ceil相对应,应该说是正好相反。ceil取定数轴右侧的第一个整数值。而Floor取定的是数轴左侧的第一个整数值,也就是取小的动作。

SQL> select id, floor(id) from t;

IDFLOOR(ID)

---------- ----------

00

11

1.31

1.51

1.81

-1-1

-1.3-2

-1.5-2

-1.8-2

9 rows selected

floor作用是找比当前值小的整数。

trunc是一个“多功能”函数。我们已经习惯其对date日期类型的处理方式。trunc输入参数是日期类型时,起到的是裁断天之后的时分秒信息。全部如期转为00:00:00。但trunc面对数字类型输入的时候,也会将小数点后面的数字截取。

SQL> select id, trunc(id) from t;

IDTRUNC(ID)

---------- ----------

00

11

1.31

1.51

1.81

-1-1

-1.3-1

-1.5-1

-1.8-1

9 rows selected

trunc对数字也没有“四舍五入”的概念,都是直接“截断处理”。严格的说,只有round才算真正有“四舍五入”的选择动作。

SQL> select id, round(id) from t;

IDROUND(ID)

---------- ----------

00

11

1.31

1.52

1.82

-1-1

-1.3-1

-1.5-2

-1.8-2

9 rows selected

只有round才有我们通常意义的四舍五入动作。

3、取整函数的精度scale取值

我们这些取整函数,一些可以带一个可选参数,用来表示设置精度。当前我们数据为状态如下:

SQL> select * from t;

ID

----------

1234.4345

1234.4392

-1234.4392

-1234.4345

trunc和round是可以支持函数scale参数的。

SQL> select id, trunc(id,1), round(id,1) from t;

ID TRUNC(ID,1) ROUND(ID,1)

---------- ----------- -----------

1234.43451234.41234.4

1234.43921234.41234.4

-1234.4392-1234.4 -1234.4

-1234.4345-1234.4-1234.4

如果设置正数,那么返回的小数点后面的位数进行处理。如果我们设置负数呢?

SQL> select id, trunc(id,-1), round(id,-1) from t;

ID TRUNC(ID,-1) ROUND(ID,-1)

---------- ------------ ------------

1234.434512301230

1234.439212301230

-1234.4392-1230-1230

-1234.4345-1230-1230

如果设置负数,就在小数点前面进行截取操作。同时,floor和ceil不支持第二个参数。

SQL> select id, ceil(id,1), floor(id,1) from t;

select id, ceil(id,1), floor(id,1) from t

ORA-00909: 参数个数无效

SQL> select id, floor(id,1) from t;

select id, floor(id,1) from t

ORA-00909: 参数个数无效

4、mod与remainder

mod取余数,我们经常用的“模”操作就是基于mod的操作。而remainder的功能也是取余数,两者有什么差别呢?

SQL> select mod(11,4), remainder(11,4) from dual;

MOD(11,4) REMAINDER(11,4)

---------- ---------------

3-1

SQL> select mod(0,4), remainder(0,4) from dual;

MOD(0,4) REMAINDER(0,4)

---------- --------------

00

SQL> select mod(-11,4), remainder(-11,4) from dual;

MOD(-11,4) REMAINDER(-11,4)

---------- ----------------

-31

当取余操作的两个参数都是整数的时候,我们基本看出什么问题。但是一旦出现负数,无论是除数还是被除数,mod的行为和经典余数模型有一些不同。

SQL> select mod(-11,-4), remainder(-11,-4) from dual;

MOD(-11,-4) REMAINDER(-11,-4)

----------- -----------------

-31

SQL> select mod(11,-4), remainder(11,-4) from dual;

MOD(11,-4) REMAINDER(11,-4)

---------- ----------------

3-1

精确的说,mod的函数取值为:n2-n1*floor(n2/n1)。所以,要注意在存在负数的时候,mod的问题。

remainder也有取余的效果,那么有什么不同的?要点就在计算公式的floor上面。对remainder而言,Oracle没有选择floor,而是round四舍五入。

5、结论

Oracle提供了很多自定义函数,用好他们、用对他们,可以给予我们很大帮助。

oracle取_后的数字,聊聊四种Oracle数字取整函数相关推荐

  1. 聊聊四种Oracle数字取整函数

    2019独角兽企业重金招聘Python工程师标准>>> "四舍五入"是我们最早接触的数学概念之一.我们日常开发系统中,数字取整也是我们最常接触的一种需求样式.在财 ...

  2. 二叉树后序遍历的四种方法

    在二叉树三种顺序的遍历中,后序遍历相对较麻烦一些,其实对于递归方法来说,三种方法大同小异,思路与实现都很简单.后序遍历的迭代法与Morris方法比较麻烦.这里介绍后序遍历的四种方法,其实还是递归.迭代 ...

  3. html设置打开页面后自动关闭,Win7系统打开IE浏览器后页面自动关闭的四种解决方法...

    很多用户都遇到一件很奇葩的问题,就是在win7系统下打开IE浏览器,浏览网页,没有进行任何操作,突然所有页面就自动关闭了,又要重新启动,没过多久又出现这样情况,怎么回事呢?导致Win7系统打开IE浏览 ...

  4. oracle取_后的数字,Oracle SQL语句实现数字四舍五入取整

    取整(向下取整): select floor(5.534) from dual; select trunc(5.534) from dual; 上面两种用法都可以对数字5.534向下取整,结果为5. ...

  5. 富士通打印机调整位置_打印机为什么卡纸 打印机四种卡纸原因及解决办法【介绍】...

    我们在使用打印机的过程中,由于频繁使用打印机,常常会出现打印机无法处理纸张的故障.大多数常见的故障就是夹纸.不进纸.一次进多页纸以及乱走纸等.我们在打印机出现这些现象的时候,该怎样去应对呢?下面为大家 ...

  6. mysql外连接插座_深入理解SQL的四种连接-左外连接、右外连接、内连接、全连接...

    1.内联接(典型的联接运算,使用像 =  或 <> 之类的比较运算符).包括相等联接和自然联接. 内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行.例如,检索 students和 ...

  7. .net npoi xssfclientanchor设置图片缩放大小_.NET导出Excel的四种方法及评测

    前言 导出Excel是.NET的常见需求,开源社区.市场上,都提供了不少各式各样的Excel操作相关包.本文,我将使用NPOI.EPPlus.OpenXML.Aspose.Cells四个市面上常见的库 ...

  8. mysql四种事务级别_【MySQL 知识】四种事务隔离级别

    摘要:本篇文章主要是为了对MySQL的四种事务隔离级别的介绍.为了保证数据库的正确性与一致性,数据库事务具有原子性(Atomicity).一致性(Consistency).隔离性(Isolation) ...

  9. 20190811:只出现一次的数字(四种解法)

    只出现一次的数字 题目 大致思路 代码实现 题目 大致思路 方法一:先排序,然后2个2个进行遍历,因为排序之后这个单独的数字一定在偶数下标对应的位置,找到不相同的这两个相邻数字,这两个数字中位于偶数下 ...

最新文章

  1. short s1 = 1; s1 = s1 + 1;和short s1 = 1; s1 += 1;的区别
  2. 二十三、Java类中重载和重写的区别
  3. 【Jetson Nano学习笔记】1. 系统镜像和ROS的安装
  4. LeetCode 1610. 可见点的最大数目(atan2函数求夹角)
  5. 深度学习在商户挂牌语义理解的实践
  6. 【微信插件】P3微信插件测试使用步骤
  7. liunx 下的动态地址分配服务DHCP
  8. nginx实现负载均衡配置
  9. ASCII码从小到大排序(字典序)
  10. boundService-AIDL
  11. java归并算法实例_Java编程中实现归并排序算法的实例教程
  12. Linux系统kill端口占用简书,MAC/Linux解决端口占用
  13. html右侧客服代码,非常好看的jQuery网站右侧固定在线客服代码
  14. word排版一般步骤
  15. 一句话理解到底什么是电平触发器,脉冲触发器,同步触发器,边沿触发器
  16. 【物联网开发基础】plc简介
  17. (前端发邮件)vue中使用smtp.js发送邮件
  18. Chartboost-x新鲜出炉: C++ Wrapper of Chartboost for Cocos2d-x
  19. Linux LibTools
  20. 金山软件刘鑫:有限使用UML

热门文章

  1. python caffe报错:No module named google
  2. OpenCV-Python教程(4、形态学处理)
  3. python控制台输出颜色
  4. no output in console for unittests in pycharm 2017
  5. 总结Hbase 与 MongoDB
  6. opencv相机标定
  7. 57 第一个Celery程序
  8. android 点击网络图片大全,android查看网络图片的实现方法
  9. 传统jdbc存在的问题总结
  10. python如何离线安装第三方库_离线环境安装python第三方库