Oracle trunc()函数详解
Posted 睡竹
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle trunc()函数详解相关的知识,希望对你有一定的参考价值。
1、功能描述
用于截取时间或者数值,返回指定的值。
2、语法
2.1、数值处理:
格式:
trunc(number,[decimals])
- number : 为必要参数,是输入的一个数值
- decimals :参数可忽略,是要截取的位数,缺省时表示截掉小数点后边的值。
案例1【第二个参数为正数时】:
select trunc(12345.6789,0) from dual --返回结果为12345 --第二个参数省略,相当于0
select trunc(12345.6789,0) from dual --返回结果为12345 --截取0位小数==去除小数
select trunc(12345.6789,1) from dual --返回结果为12345.6 --截取一位小数
select trunc(12345.6789,2) from dual --返回结果为12345.67
select trunc(12345.6789,5) from dual --返回结果为12345.6789
案例2【第二个参数为负数时】:
select trunc(12345.6789,-1) from dual --返回结果为12340,-1相当于整数位截取一位,这里的截取是把数值直接变为0,不会去截取位数,更不会四舍五入
select trunc(12345.6789,-2) from dual --返回结果为12300
select trunc(12345.6789,-3) from dual --返回结果为12000
select trunc(12345.6789,-4) from dual --返回结果为10000
select trunc(12345.6789,-5) from dual --返回结果为0
2.2、日期处理:
格式:
trunc(date,[format])
- date :为必要参数,是输入的一个date日期值
- format :参数可忽略,是日期格式
format 常用取值:
- 缺省: 获取当前年月日:如:2022/7/21
- y或yy或yyy或yyyy或year: y 都是获取今天的一月一日:如:2022/1/1
- 'mm'或'month' 当月的第一天:如:2022/7/1
- 'q': 本星期的第一天【是周日而不是周一】
- 'hh': 当前的小时:如:2022/7/21 17:00:00
- 'mi': 当前的时分:如:2022/7/21 17:48:00
案例1【缺省】
错误使用:
select trunc('2022/07/21') from dual --报错,'2022/7/21'是一个字符串,不是date类型
正确方式:
--使用to_date函数,把字符串转为日期格式,注意:to_date的日期格式默认为yyyy/mm/dd
select trunc(to_date('2022/07/21','YYYY/MM/DD')) from dual
结果:
2022/7/21
为了方便学习trunc函数,以下案例,都是用sysdate来代替日期数据【sysdate为当前时间】
如【我当前时间为2022/7/21】:
select sysdate from dual --结果为当前时间:2022/7/21 17:18:18
select trunc(sysdate) from dual --结果为2022/7/21
案例2【参数2位“y”】
select trunc(sysdate,'y') from dual --结果为:2022/7/21
select trunc(sysdate,'yy') from dual --结果为:2022/7/21
select trunc(sysdate,'yyy') from dual --结果为:2022/7/21
select trunc(sysdate,'yyyy') from dual --结果为:2022/7/21
案例3【参数2位“mm”】
select trunc(sysdate,'mm') from dual --结果为:2022/7/1
select trunc(sysdate,'month') from dual --结果为:2022/7/1
案例4【参数2位“q”】
select trunc(sysdate,'d') from dual --结果为:2022/7/17
案例5【参数2位“hh”】
select trunc(sysdate,'hh') from dual --结果为:2022/7/21 17:00:00
案例6【参数2位“mi”】
select trunc(sysdate,'mi') from dual --结果为:2022/7/21 17:48:00
案例7
select trunc(sysdate) -1/24 from dual --结果为2022/7/20 23:00:00【当前日期为:2022/7/21】 -1/24表示24点的前1个小时
select trunc(sysdate) +2/24 from dual --结果为2022/7/21 2:00:00 +2/24表示24点的后2个小时
trunc函数 oracle
1,【trunc(for dates)】TRUNC()函数处理日期
select trunc(sysdate,‘yy‘) from dual;--返回当年第一天
select trunc(sysdate,‘mm‘) from dual;--返回当月的第一天
select trunc(sysdate,‘dd‘) from dual;--返回当前日期
2,【TRUNC(for number)】TRUNC()函数处理number型数字
select trunc(123.567,2) from dual;--123.56,将小数点右边指定位数后面的截去;
select trunc(123.567,-2) from dual;--100,第二个参数可以为负数,表示将小数点左边指定位数后面的部分截去,即均以0记;
select trunc(123.567) from dual;--123,默认截去小数点后面的部分;
以上是关于Oracle trunc()函数详解的主要内容,如果未能解决你的问题,请参考以下文章