网站首页 > 技术文章 正文
概述
“四舍五入”是我们最早接触的数学概念之一,数字取整也是我们最常接触的一种需求样式。在财务相关系统中,四舍五入的算法有时候对系统用户造成巨大的影响。
在Oracle SQL中,提供了四种数字取整函数。从名称上,他们都是在取整,但是具体算法有所不同。
1、环境介绍和准备
这里选择Oracle 11gR2版本进行测试。
SQL> select * from v$version;
不同种类数据进行测试。
SQL> select * from t;
2、四种基本取整函数
Oracle中的四种有取证功能函数为:ceil、floor、trunc和round,每一个都有不同的含义和特点,适合不同的场景。
2.1、ceil
Ceil的原始含义是说:返回比当前值大的第一个整数。这里要注意“大”的概念,最简单的理解就是我们数学上的数轴。Ceil就是返回当前值在数轴往右第一个整数值。
SQL> select id, ceil(id) from t;
这里主要注意负数的ceil结果,和我们直观的想法有一些差异。而且ceil并没有进行四舍五入。
2.2、floor
Floor与ceil相对应,应该说是正好相反。ceil取定数轴右侧的第一个整数值。而Floor取定的是数轴左侧的第一个整数值,也就是取小的动作。
SQL> select id, floor(id) from t;
floor作用是找比当前值小的整数。
2.3、trunc
trunc是一个“多功能”函数。我们已经习惯其对date日期类型的处理方式。trunc输入参数是日期类型时,起到的是裁断天之后的时分秒信息。全部如期转为00:00:00。但trunc面对数字类型输入的时候,也会将小数点后面的数字截取。
SQL> select id, trunc(id) from t;
trunc对数字也没有“四舍五入”的概念,都是直接“截断处理”。
2.4、round
严格的说,只有round才算真正有“四舍五入”的选择动作。
SQL> select id, round(id) from t;
只有round才有我们通常意义的四舍五入动作。
3、取整函数的精度scale取值
这些取整函数,一些可以带一个可选参数,用来表示设置精度。当前我们数据为状态如下:
SQL> select * from t;
trunc和round是可以支持函数scale参数的。
SQL> select id, trunc(id,1), round(id,1) from t;
如果设置正数,那么返回的小数点后面的位数进行处理。如果我们设置负数呢?
SQL> select id, trunc(id,-1), round(id,-1) from t;
如果设置负数,就在小数点前面进行截取操作。
4、mod与remainder
mod取余数,我们经常用的“模”操作就是基于mod的操作。而remainder的功能也是取余数,两者有什么差别呢?
SQL> select mod(11,4), remainder(11,4) from dual; SQL> select mod(0,4), remainder(0,4) from dual; SQL> select mod(-11,4), remainder(-11,4) from dual;
当取余操作的两个参数都是整数的时候,我们基本看出什么问题。但是一旦出现负数,无论是除数还是被除数,mod的行为和经典余数模型有一些不同。
SQL> select mod(-11,-4), remainder(-11,-4) from dual; SQL> select mod(11,-4), remainder(11,-4) from dual;
精确的说,mod的函数取值为:n2-n1*floor(n2/n1)。所以,要注意在存在负数的时候,mod的问题。
remainder也有取余的效果,那么有什么不同的?要点就在计算公式的floor上面。对remainder而言,Oracle没有选择floor,而是round四舍五入。
总结
Oracle提供了很多自定义函数,用好他们、用对他们,可以给予我们很大帮助。
后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注一下~
猜你喜欢
- 2025-07-14 Oracle字符串转日期错误,试试TO_TIMESTAMP函数
- 2024-10-20 1 小时 SQL 极速入门(三)——分析函数
- 2024-10-20 oracle中常用的一些函数,巧用函数,减少代码量
- 2024-10-20 Oracle常用系统函数-日期和时间类函数
- 2024-10-20 oracle 函数decode用法 oracle的decode方法
- 2024-10-20 数据库笔试面试5——在Oracle中,函数的描述正确的是
- 2024-10-20 ORACLE 取两张表差值函数 minus oracle查询两个表中相同数据
- 2024-10-20 Oracle行转列、列转行函数 oracle12c行转列函数
- 2024-10-20 用ORACLE分析函数decode实现行列转换
- 2024-10-20 2周零基础搞定SQL——窗口函数 sql 窗口函数执行顺序
你 发表评论:
欢迎- 624℃几个Oracle空值处理函数 oracle处理null值的函数
- 616℃Oracle分析函数之Lag和Lead()使用
- 605℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 601℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 596℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 589℃【数据统计分析】详解Oracle分组函数之CUBE
- 577℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 565℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- 国产化红利到底在哪?好多人都在瞎折腾
- Oracle 推出 Java 24,增强 AI 支持和后量子加密
- JAVA桥接模式适用场景,优缺点是什么你知道吗,这篇文章彻底讲透
- SpringBoot条件化配置(@Conditional)全面解析与实战指南
- Navicat Data Modeler使用教程十二:配置
- 软件测试|数据库的内连接,左连接,右链接分别是什么
- 每日学习“IT”是什么呢?(每日学习每日一词)
- SQLite:小众?其实它比你想象的更普及,连这个领域都有人用!
- 【推荐】一款实用且跨平台的数据库管理神器,支持Web浏览器
- Spring Batch中的JobRepository:批处理的“记忆大师”是如何工作
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)