Oracle 日期计算 与 ROUND TRUNC 函数日期计算

 

SQL*Plus: Release 10.2.0.1.0 - Production on D??ú?t 9?? 4 10:11:57 2012

Copyright (c) 1982, 2005, Oracle.  All rights reserved.


á??óμ?: 
Oracle Database 10g Enterprise Edition Release 10.2.0.3.0 - Production
With the Partitioning, OLAP and Data Mining options

mdev@mdev-192.168.16.35> -- 当前时间
mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT SYSDATE FROM DUAL;

SYSDATE
--------------
04-9?? -12

mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> -- 设置相近时间
mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT TO_DATE('2012/09/04 08:00:00', 'YYYY/MM/DD HH24:MI:SS') FROM DUAL;

TO_DATE('2012/
--------------
04-9?? -12

mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> -- 两个时间相减: 差值——天数
mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT   TO_DATE('2012/09/04 08:00:00', 'YYYY/MM/DD HH24:MI:SS')
  2         - TO_DATE('2012/09/03 08:00:00', 'YYYY/MM/DD HH24:MI:SS')
  3    FROM DUAL;

TO_DATE('2012/09/0408:00:00','YYYY/MM/DDHH24:MI:SS')-TO_DATE('2012/09/0308:00:00','YYYY/MM/DDHH24:MI
----------------------------------------------------------------------------------------------------
                                                                                                        1

mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT SYSDATE - TO_DATE('2012/09/04 08:00:00', 'YYYY/MM/DD HH24:MI:SS')
  2    FROM DUAL;

SYSDATE-TO_DATE('2012/09/0408:00:00','YYYY/MM/DDHH24:MI:SS')
------------------------------------------------------------
                                                  .072326389

mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> -- 两个时间相减:差值——小时数
mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT   (SYSDATE - TO_DATE('2012/09/04 08:00:00', 'YYYY/MM/DD HH24:MI:SS')
)
  2         * 24
  3    FROM DUAL;

(SYSDATE-TO_DATE('2012/09/0408:00:00','YYYY/MM/DDHH24:MI:SS'))*24
-----------------------------------------------------------------
                                                       1.73583333

mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> -- 两个时间相减:差值——分钟数
mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT   (SYSDATE - TO_DATE('2012/09/04 08:00:00', 'YYYY/MM/DD HH24:MI:SS')
)
  2         * 24
  3         * 60
  4    FROM DUAL;

(SYSDATE-TO_DATE('2012/09/0408:00:00','YYYY/MM/DDHH24:MI:SS'))*24*60
--------------------------------------------------------------------
                                                              104.15

mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> -- 两个时间相减:差值——秒数
mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT   (SYSDATE - TO_DATE('2012/09/04 08:00:00', 'YYYY/MM/DD HH24:MI:SS')
)
  2         * 24
  3         * 60
  4         * 60
  5    FROM DUAL;

(SYSDATE-TO_DATE('2012/09/0408:00:00','YYYY/MM/DDHH24:MI:SS'))*24*60*60
-----------------------------------------------------------------------
                                                                   6249

mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> -- ROUND函数将该天的时间设置为零点,如果其时间为下午之后,设置为次日的零点
mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT   TO_DATE('2012/09/04 00:00:00', 'YYYY/MM/DD HH24:MI:SS')
  2         - ROUND(TO_DATE('2012/09/04 11:59:59', 'YYYY/MM/DD HH24:MI:SS'))
  3    FROM DUAL;

TO_DATE('2012/09/0400:00:00','YYYY/MM/DDHH24:MI:SS')-ROUND(TO_DATE('2012/09/0411:59:59','YYYY/MM/DDH
----------------------------------------------------------------------------------------------------
                                                                                                               0

mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT   TO_DATE('2012/09/04 00:00:00', 'YYYY/MM/DD HH24:MI:SS')
  2         - ROUND(TO_DATE('2012/09/04 12:00:00', 'YYYY/MM/DD HH24:MI:SS'))
  3    FROM DUAL;

TO_DATE('2012/09/0400:00:00','YYYY/MM/DDHH24:MI:SS')-ROUND(TO_DATE('2012/09/0412:00:00','YYYY/MM/DDH
----------------------------------------------------------------------------------------------------
                                                                                                              -1

mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT   TO_DATE('2012/09/04 00:00:00', 'YYYY/MM/DD HH24:MI:SS')
  2         - ROUND(TO_DATE('2012/09/05 11:59:59', 'YYYY/MM/DD HH24:MI:SS'))
  3    FROM DUAL;

TO_DATE('2012/09/0400:00:00','YYYY/MM/DDHH24:MI:SS')-ROUND(TO_DATE('2012/09/0511:59:59','YYYY/MM/DDH
----------------------------------------------------------------------------------------------------
                                                                                                              -1

mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> -- TRUNC函数的功能与之类似,只不过将任何时间,包括午夜后一秒也设置为零点
mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT   TO_DATE('2012/09/04 00:00:00', 'YYYY/MM/DD HH24:MI:SS')
  2         - TRUNC(TO_DATE('2012/09/04 11:59:59', 'YYYY/MM/DD HH24:MI:SS'))
  3    FROM DUAL;

TO_DATE('2012/09/0400:00:00','YYYY/MM/DDHH24:MI:SS')-TRUNC(TO_DATE('2012/09/0411:59:59','YYYY/MM/DDH
----------------------------------------------------------------------------------------------------
                                                                                                               0

mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT   TO_DATE('2012/09/04 00:00:00', 'YYYY/MM/DD HH24:MI:SS')
  2         - TRUNC(TO_DATE('2012/09/04 12:00:00', 'YYYY/MM/DD HH24:MI:SS'))
  3    FROM DUAL;

TO_DATE('2012/09/0400:00:00','YYYY/MM/DDHH24:MI:SS')-TRUNC(TO_DATE('2012/09/0412:00:00','YYYY/MM/DDH
----------------------------------------------------------------------------------------------------
                                                                                                               0

mdev@mdev-192.168.16.35> 
mdev@mdev-192.168.16.35> SELECT   TO_DATE('2012/09/04 00:00:00', 'YYYY/MM/DD HH24:MI:SS')
  2         - TRUNC(TO_DATE('2012/09/05 11:59:59', 'YYYY/MM/DD HH24:MI:SS'))
  3    FROM DUAL;

TO_DATE('2012/09/0400:00:00','YYYY/MM/DDHH24:MI:SS')-TRUNC(TO_DATE('2012/09/0511:59:59','YYYY/MM/DDH
----------------------------------------------------------------------------------------------------
                                                                                                              -1

mdev@mdev-192.168.16.35> 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值