用于截取时间或者数值,返回指定的值。
格式:
trunc(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
格式:
trunc(date,[format])
format 常用取值:
案例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个小时
到此这篇关于Oracle中trunc()函数详解的文章就介绍到这了,更多相关Oracle trunc()函数详解内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!