Oracle trunc和round的区别
1、关于trunc 和round函数比较
整体概括:
round函数 四舍五入
trunc函数 直接截取
对于时间:
Round函数对日期进行“四舍五入”,Trunc函数对日期进行截取。如果我们不指定格式的话,Round会返回一个最接近date参数的日期,而Trunc函数只会简单的截取时分秒部分,返回年月日部分
对于数字:
Round函数对数字同样进行“四舍五入”,Trunc函数截取时不进行四舍五入,可以指明保留小数点后面的位数。
2、Round、Trunc用法
- /**************************For date****************************/
- --Trunc函数
- SELECT TRUNC(SYSDATE), -- 今天的日期为 2014-05-08
- TRUNC(SYSDATE, 'YYYY'), --返回当年第一天 2014-01-01 yyyy/yy/year 年
- TRUNC(SYSDATE, 'MM'), --返回当月第一天 2014-05-01 mm/month 月
- TRUNC(SYSDATE, 'DD'), --返回当前年月日 2014-05-08 d/day 周
- TRUNC(SYSDATE, 'D'), --(星期天)返回当前星期的第一天 2014-05-04
- TRUNC(SYSDATE, 'HH'), --返回当前时间精确小时 2014-05-08 11:00:00
- TRUNC(SYSDATE, 'MI') -- 返回当前时间精确分钟 2014-05-08 11:06:00 TRUNC()函数没有秒的精确
- FROM DUAL;
- --Round函数
- select Round(sysdate, 'Q') Rnd_Q, --2014-04-01
- Round(sysdate, 'Month') Rnd_Month, --2014-05-01
- Round(sysdate, 'WW') Rnd_Week, --2014-05-07
- Round(sysdate, 'W') Rnd_Week_again, --2014-05-08
- Round(sysdate, 'DDD') Rnd_day, --2014-05-08
- Round(sysdate, 'DD') Rnd_day_again, --2014-05-08
- Round(sysdate, 'DAY') Rnd_day_of_week, --2014-05-11
- Round(sysdate, 'D') Rnd_day_of_week_again, --2014-05-11
- Round(sysdate, 'HH12') Rnd_hour_12, --2014-05-08 12:00:00
- Round(sysdate, 'HH24') Rnd_hour_24, --2014-05-08 12:00:00
- Round(sysdate, 'MI') Rnd_minute --2014-05-08 11:52:00
- from dual;
- /****************************For number************************/
- /**
- --TRUNC(number,num_digits)
- Number 需要截尾取整的数字。
- Num_digits 指明需保留小数点后面的位数。可选项,忽略他则截去任何的小数部分,Num_digits 的默认值为 0,
- --此参数够为负数,表示为小数点左边指定位数后面的部分截去,即均以0记。
- TRUNC()函数截取时不进行四舍五入**/
- --TRUNC函数
- select TRUNC(123.458), --123
- TRUNC(123.458, 0), --123
- TRUNC(123.458, 1), --123.4
- TRUNC(123.458, 2), --123.45
- TRUNC(123.458, 3), --123.458
- TRUNC(123.458, 4), --123.458
- TRUNC(123.458, -1), --120
- TRUNC(123.458, -2), --100
- TRUNC(123.458, -3), --0
- TRUNC(123.458, -4), --0
- TRUNC(123), --123
- TRUNC(123, 1), --123
- TRUNC(123, 2), --123
- TRUNC(123, 3), --123
- TRUNC(123, 4) --123
- from dual;
- --Round函数
- select Round(123.458), --123
- Round(123.458, 0), --123
- Round(123.458, 1), --123.5
- Round(123.458, 2), --123.46
- Round(123.458, 3), --123.458
- Round(123.458, 4), --123.458
- Round(123.458, -1), --120
- Round(123.458, -2), --100
- Round(123.458, -3), --0
- Round(123.458, -4), --0
- Round(123), --123
- Round(123, 1), --123
- Round(123, 2), --123
- Round(123, 3), --123
- Round(123, 4) --123
- from dual;
round(x[,y])
【功能】返回四舍五入后的值
【参数】x,y,数字型表达式,如果y不为整数则截取y整数部分,如果y>0则四舍五入为y位小数,如果y小于0则四舍五入到小数点向左第y位。
【返回】数字
【示例】 select round(5555.6666,2.1),round(5555.6666,-2.6),round(5555.6666) from dual;
返回: 5555.67 , 5600 , 5556
【相近】trunc(x[,y]) 返回截取后的值,用法同round(x[,y]),只是不四舍五入
trunc(x[,y])
【功能】返回x按精度y截取后的值
【参数】x,y,数字型表达式,如果y不为整数则截取y整数部分,如果y>0则截取到y位小数,如果y小于0则截取到小数点向左第y位,小数前其它数据用0表示。
【返回】数字
【示例】 select trunc(5555.66666,2.1),trunc(5555.66666,-2.6),trunc(5555.033333) from dual;
返回:5555.66 5500 5555
【相近】round(x[,y]) 返回截取后的值,用法同trunc(x[,y]),只是要做四舍五入
Oracle trunc和round的区别的更多相关文章
- 【测试】trunc和round的区别
trunc是截断:round是四舍五入:下面通过一个例子具体看一下trunc和round的不同 SQL),trunc() from dual; TRUNC() TRUNC() ------------ ...
- Oracle trunc()函数的用法及四舍五入 round函数
--Oracle trunc()函数的用法/**************日期********************/1.select trunc(sysdate) from dual --2011 ...
- Oracle trunc函数
--Oracle trunc()函数的用法/**************日期********************/1.select trunc(sysdate) from dual --2011 ...
- Oracle trunc()函数的用法--来着心静禅定ing
1.TRUNC(for dates) TRUNC函数为指定元素而截去的日期值. 其具体的语法格式如下: TRUNC(date[,fmt]) 其中: date 一个日期值 fmt 日期格式,该日期将由指 ...
- [转]Oracle trunc()函数的用法
原文地址:http://www.cnblogs.com/gengaixue/archive/2012/11/21/2781037.html 1.TRUNC(for dates) TRUNC函数为指定元 ...
- Oracle trunc()函数的用法
Oracle trunc()函数的用法 /**************日期********************/1.select trunc(sysdate) from dual --2013-0 ...
- oracle的oci和thin区别(数据源)
我是今天看到tomcat数据源的配置时,想起来这个问题,刚开始还不晓得thin是什么东西! database.url=jdbc:oracle:thin:angel/oracle@192.168.55. ...
- oracle获取本月第一天和最后一天及Oracle trunc()函数的用法
select to_char(trunc(add_months(last_day(sysdate), -1) + 1), 'yyyy-mm-dd') "本月第一天", to_cha ...
- Oracle trunc()函数
Oracle trunc()函数的用法 --Oracle trunc()函数的用法/**************日期********************/1.select trunc(sysd ...
随机推荐
- 【前端工具】nodejs+npm+vue 安装(windows)
预备 先看看这几个是干嘛的,相互的关系是啥. nodejs是语言,类比到php. npm是个包管理,类比到composer. vue是个框架,类比到laravel. webpack是个打包工具. 先下 ...
- 简单理解函数声明(以signal函数为例)
这两天遇到一些声明比较复杂的函数,比如signal函数,那我们先简单说说signal函数的用法:(参考<c陷阱与缺陷>) [signal:几乎所有c语言程序的实现过程中都要用到signal ...
- 不破不立,祝贺EDG夺得S11冠军。这一夜,我看到太多Flag成真
在昨晚11月6号夜进行的2021英雄联盟S11总决赛中,中国战队EDG夺冠!全国各地高校的男生宿舍像过年一般庆祝夺冠,高呼:EDG世界冠军! 前三局1:2的劣势下,第四局十分胶着,最终EDG顽 ...
- [JavaScript闭包]Javascript闭包的判别,作用和示例
闭包是JavaScript最重要的特性之一,也是全栈/前端/JS面试的考点. 那闭包究竟该如何理解呢? 如果不爱看文字,喜欢看视频.那本文配套讲解视频已发送到B站上供大家参考学习. 如果觉得有所收获, ...
- SpringCloud升级之路2020.0.x版-33. 实现重试、断路器以及线程隔离源码
本系列代码地址:https://github.com/JoJoTec/spring-cloud-parent 在前面两节,我们梳理了实现 Feign 断路器以及线程隔离的思路,并说明了如何优化目前的负 ...
- [第三章]c++学习笔记2(静态成员变量)
静态成员:在说明前加了static关键字的对象 使用例: 基本概念 普通成员变量每个对象有各自的一份,而静态成员变量总共只有一份,为所有对象共享. 普通成员函数必须具体作用与某个对象,而静态成员函数并 ...
- 基于Mui与H5+开发webapp的Android原生工程打包步骤(使用新版本5+SDK与Android studio)(部分内容转自dcloud官网)
文章背景: dcloud官网给出的打包步骤对于有一定安卓打包基础的同学来说比较容易掌握,但是对于webapp小白来讲有的地方可能没有说的太具体.下面我给大家介绍的详细一点,保证大家按照步骤就能学会打包 ...
- js-sequence-diagrams > 时序图
... <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title ...
- Spring Cloud Gateway自定义过滤器实战(观测断路器状态变化)
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- [cf611H]New Year and Forgotten Tree
首先,来构造这棵树的形态 称位数相同的点为一类点,从每一类点中任选一个点,具有以下性质: 1.每一类中选出的点的导出子图连通(是一颗树) 2.每一条边必然有一个端点属于某一类中选出的点 (关于&quo ...