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 常用取值:

  1. 缺省:                                  获取当前年月日:如:2022/7/21 
  2. y或yy或yyy或yyyy或year:  y 都是获取今天的一月一日:如:2022/1/1
  3. 'mm'或'month'                      当月的第一天:如:2022/7/1
  4. 'q':                                      本星期的第一天【是周日而不是周一】
  5. 'hh':                                    当前的小时:如:2022/7/21 17:00:00
  6. '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个小时

  • 19
    点赞
  • 107
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

睡竹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值