Oracle时间运算(日期截取及四舍五入)

Oracle时间运算(日期截取及四舍五入)

  如同对数字进行四舍五入和按位截取一样,Oracle对时间日期也提供了这两种功能。但比起对数字进行四舍五入和截取比较复杂:这是因为时间日期是有格式的。下面看看这两个函数的定义和用途:

  ROUND(date [, format])

  TRUNC(date [, format])

  Round函数对日期进行“四舍五入”,Trunc函数对日期进行截取。如果我们不指定格式的话,Round会返回一个最接近date参数的日期,而Trunc函数只会简单的截取时分秒部分,返回年月日部分。

  二、Round和Trunc函数示例:

  SQL> select to_char(sysdate, 'yyyy-mm-dd hh24:mi:ss') now_date,

  2 to_char(Round(sysdate),'yyyy-mm-dd hh24:mi:ss') round_date,

  3 to_char(Trunc(sysdate),'yyyy-mm-dd hh24:mi:ss') trunc_date

  4 from dual;

  NOW_DATE ROUND_DATE TRUNC_DATE

  -------------------------------------- -------------------------------------- ----------------------

  2008-06-30 14:52:13 2008-07-01 00:00:00 2008-06-30 00:00:00

  这是一个典型的例子,由于我们没有指定round和trunc函数的格式,所以Oracle默认采用了按日期时间的格式,该例子中当前的时间是下午14:52分,已经超过了12:00 AM这个中界线,所以Round返回07-01日而非06-30日。而Trunc不管三七二十一直接截取前面日期部分返回。

  另外一个值得注意的地方是这两个函数返回的时分秒都是00:00:00,即一天的开始时间(对于12小时制的返回的是12:00:00 AM)。

  三、指定格式的Round和Trunc函数示例:

  如果我们对Round函数和Trunc函数指定了格式,事情就变得有点复杂了,不过核心思想还是不变:Round是四舍五入,Trunc是截取。举个例子来说,假如我们以年为格式,则现在Oracle的判断是基于年来判断,超过一年的一半(即6月30日),Round函数则返回下一年了,Trunc函数依然返回当前年。

  SQL> select sysdate "Now date",

  2 Round(sysdate, 'yyyy') Round_year,

  3 Trunc(sysdate, 'yyyy') Trunc_year

  4 from dual;

  Now date ROUND_YEAR TRUNC_YEAR

  ---------- ---------- ----------

  30-6月 -08 01-1月 -08 01-1月 -08

  关于这两个函数可用的格式非常多,但日常应用中用得比较多的基本上就这几个,以Round函数为例:

  select Round(sysdate, 'Q') Rnd_Q,

  Round(sysdate, 'Month') Rnd_Month,

  Round(sysdate, 'WW') Rnd_Week,

  Round(sysdate, 'W') Rnd_Week_again,

  Round(sysdate, 'DDD') Rnd_day,

  Round(sysdate, 'DD') Rnd_day_again,

  Round(sysdate, 'DAY') Rnd_day_of_week,

  Round(sysdate, 'D') Rnd_day_of_week_again,

  Round(sysdate, 'HH12') Rnd_hour_12,

  Round(sysdate, 'HH24') Rnd_hour_24,

  Round(sysdate, 'MI') Rnd_minute

  from dual

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值