oracle取_后的数字,聊聊四种Oracle数字取整函数

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

在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

CORE   11.2.0.1.0 Production

不同种类数据进行测试。

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;

ID  CEIL(ID)

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

0         0

1         1

1.3         2

1.5         2

1.8         2

-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;

ID FLOOR(ID)

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

0         0

1         1

1.3         1

1.5         1

1.8         1

-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;

ID TRUNC(ID)

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

0         0

1         1

1.3         1

1.5         1

1.8         1

-1        -1

-1.3        -1

-1.5        -1

-1.8        -1

9 rows selected

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

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

ID ROUND(ID)

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

0         0

1         1

1.3         1

1.5         2

1.8         2

-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参数的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值