Oracle实验--探讨四种Oracle数字取整函数
mhr18 2024-09-18 20:32 21 浏览 0 评论
概述
“四舍五入”是我们最早接触的数学概念之一,数字取整也是我们最常接触的一种需求样式。在财务相关系统中,四舍五入的算法有时候对系统用户造成巨大的影响。
在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方面的内容,感兴趣的朋友可以关注一下~
相关推荐
- 经典技术干货分享:JVM内存模型和垃圾回收机制
-
来源:全栈工程师小辉JVM内存模型根据Java虚拟机规范,Java数据区域分为五大数据区域。其中方法区和堆是所有线程共享的,虚拟机栈、本地方法栈和程序计数器则为线程私有的。有的博客称方法区是永久代...
- 让我来告诉你:最重要的 JVM 参数总结
-
1.概述在本篇文章中,你将掌握最常用的JVM参数配置。如果对于下面提到了一些概念比如堆、#2.堆内存相关Java虚拟机所管理的内存中最大的一块,Java堆是所有线程共享的一块内存区域,在虚拟机...
- 说一下 JVM 的内存布局和运行原理?
-
JVM(JavaVirtualMachine,Java虚拟机)顾名思义就是用来执行Java程序的“虚拟主机”,实际的工作是将编译的class代码(字节码)翻译成底层操作系统可以运行的机器...
- 这些不可不知的JVM知识,我都用思维导图整理好了
-
VM是面试中必问的部分,本文通过思维导图以面向面试的角度整理JVM中不可不知的知识。先上图:JVM必备知识1、JVM基本概念1.1、JVM是什么JVM的全称是「JavaVirtualMachi...
- 认识Kotlin_了解Kotlin和JVM虚拟机关系_重要性_更强大的跨平台
-
1.谷歌支持Kotlin作为android第一开发语言,因为java是已经被oracle收购了,可能会对Google收费.2.可以看到java语言写的android程序,实际上回编译成字节码,在jvm...
- 美团一面:为什么线程崩溃崩溃不会导致 JVM 崩溃
-
网上看到一个很有意思的美团面试题:为什么线程崩溃崩溃不会导致JVM崩溃,这个问题我看了不少回答,但发现都没答到根上,所以决定答一答,相信大家看完肯定会有收获,本文分以下几节来探讨线程崩溃,进程一定...
- 一篇文章掌握整个JVM,JVM超详细解析!!!
-
不懂JVM看完这一篇文章你就会非常懂了,文章很长,非常详细!!!先想想一些问题1我们开发人员编写的Java代码是怎么让电脑认识的首先先了解电脑是二进制的系统,他只认识01010101比如我们经常要...
- Java反射机制最全详解(图文全面总结)
-
Java反射是各种框架以及中间件实现的基石,也是大厂面试重点考察内容,下面全面来详解Java反射机制@mikechen本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。Java反...
- OCP 专家认证培训- 数据库专业人士的进阶阶梯
-
认证简介OCP即Oracle数据库认证专家,是Oracle公司的Oracle数据库DBA(DatabaseAdministrator数据库管理员)认证课程。通过该认证,表明持证人能...
- 《塞尔达传说》进化史!一口气看完全部塞尔达传说!
-
《塞尔达传说》系列全版本历史回顾以下是塞尔达传说系列所有官方游戏版本的完整列表,按时间顺序排列:主要正统系列作品1、《塞尔达传说》/TheLegendofZelda(1986)《塞尔达传说》是...
- Linux文件系统结构全解析(linux文件系统概述)
-
对Linux新手而言,“一切皆文件”的设计哲学常让人既兴奋又困惑——打开终端输入ls/,看到的bin、etc、var等目录到底有什么用?如何快速定位关键文件?本文将从Linux文件系统的底层逻...
- 一文带您了解数据库的行列之争:行式与列式存储的异同
-
数据库存储格式是数据库管理系统中一个至关重要的方面,它直接影响到数据的组织和检索效率。在数据库中,有两种主要的存储格式,即行式存储和列式存储。这两者采用截然不同的方法来组织和存储数据,各自具有一系列优...
- NL2SQL(三)开源项目怎么选:talk is cheap, show me the code!
-
老规矩,先看效果下面的demo来自试用的SuperSonic,将会在下面详细介绍:大模型时代Text-to-SQL特点随着基于LLM技术的发展,RAG/AIAgent/Fine...
- JDK25长期支持版九月降临:18项王炸功能全解析
-
Java要放大招啦!9月份推出的JDK25长期支持版已经锁定18个超能力,从稳定值到结构化并发,还有Linux系统下的"预知未来"性能分析!下面我用打游戏的术语给你们掰扯明白:1、飞...
- OceanBase 推出单机版 高度兼容MySQL和Oracle
-
【环球网科技综合报道】3月27日,独立数据库厂商OceanBase正式发布单机版产品。据悉,这一产品基于自主研发的单机分布式一体化架构设计,具备极简数据库架构和高度兼容性,为中小规模业务提供兼具性能与...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle位图索引 (74)
- oracle批量插入数据 (65)
- oracle事务隔离级别 (59)
- oracle 空为0 (51)
- oracle主从同步 (55)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)