设为首页 收藏本站
查看: 729|回复: 0

[经验分享] Oracle开发--日期截取及四舍五入

[复制链接]
YunVN网友  发表于 2016-8-14 06:01:25 |阅读模式
  一、Oracle中的Round和Trunc:

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

ROUND(date [, format])

TRUNC(date [, format])

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

二、Round和Trunc函数示例:

DSC0000.gif 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:00AM这个中界线,所以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


原文地址:http://www.blogjava.net/pengpenglin/archive/2008/06/30/211657.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-257225-1-1.html 上篇帖子: sql*plus下远程连接oracle数据库 下篇帖子: oracle 用PLSQL Developer(或者导出命令)怎么导出
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表