当前位置: 网学 > 编程文档 > ORACLE > 正文

Oracle里时间的应用

来源:Http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 12/10/19
下载{$ArticleTitle}原创论文样式
r_date,  
add_months(hiredate,rownum)+rownum newer_date  
from emp )  
)  

14.  
处理月份天数不定的办法  
select to_char(add_months(last_day(sysdate) +1, -2), ''''yyyymmdd''''),last_day(sysdate) from dual  

16.  
找出今年的天数  
select add_months(trunc(sysdate,''''year''''), 12) - trunc(sysdate,''''year'''') from dual  

闰年的处理方法  
to_char( last_day( to_date(''''02'''' || :year,''''mmyyyy'''') ), ''''dd'''' )  
如果是28就不是闰年  

17.  
yyyy与rrrr的区别  
''''YYYY99 TO_C  
------- ----  
yyyy 99 0099  
rrrr 99 1999  
yyyy 01 0001  
rrrr 01 2001  

18.不同时区的处理  
select to_char( NEW_TIME( sysdate, ''''GMT'''',''''EST''''), ''''dd/mm/yyyy hh:mi:ss'''') ,sysdate  
from dual;  

19.  
5秒钟一个间隔  
Select TO_DATE(FLOOR(TO_CHAR(sysdate,''''SSSSS'''')/300) * 300,''''SSSSS'''') ,TO_CHAR(sysdate,''''SSSSS'''')  
from dual  

2002-11-1 9:55:00 35786  
SSSSS表示5位秒数  

20.  
一年的第几天  
select TO_CHAR(SYSDATE,''''DDD''''),sysdate from dual  
310 2002-11-6 10:03:51  

21.计算小时,分,秒,毫秒  
select  
Days,  
A,  
TRUNC(A*24) Hours,  
TRUNC(A*24*60 - 60*TRUNC(A*24)) Minutes,  
TRUNC(A*24*60*60 - 60*TRUNC(A*24*60)) Seconds,  
TRUNC(A*24*60*60*100 - 100*TRUNC(A*24*60*60)) mSeconds  
from  
(  
select  
trunc(sysdate) Days,  
sysdate - trunc(sysdate) A  
from dual  
)  



select * from tabname  
order by decode(mode,''''FIFO'''',1,-1)*to_char(rq,''''yyyymmddhh24miss'''');  

//  
floor((date2-date1) /365) 作为年  
floor((date2-date1, 365) /30) 作为月  
mod(mod(date2-date1, 365), 30)作为日.  
23.next_day函数  
next_day(sysdate,6)是从当前开始下一个星期五。后面的数字是从星期日开始算起。  
1 2 3 4 5 6 7  
日 一 二 三 四 五 六

oracle中有很多关于日期的函数

在oracle中有很多关于日期的函数,如:
1、add_months()用于从一个日期值增加或减少一些月份
date_value:=add_months(date_value,number_of_months)
例:
SQL> select add_months(sysdate,12) "Next Year" from dual;

Next Year
----------
13-11月-04

SQL> select add_months(sysdate,112) "Last Year" from dual;

Last Year
----------
13-3月 -13

SQL>

2、current_date()返回当前会放时区中的当前日期
date_value:=current_date
SQL> column sessiontimezone for a15
SQL> select sessiontimezone,current_date from dual;

SESSIONTIMEZONE CURRENT_DA
--------------- ----------
+08:00 13-11月-03

SQL> alter session set time_zone=''''-11:00''''
  2 /

会话已更改。

SQL> select sessiontimezone,current_timestamp from dual;

SESSIONTIMEZONE CURRENT_TIMESTAMP
--------------- -----------------
  • 下一篇资讯: Oracle维护常用SQL语句
  • 网学推荐

    免费论文

    原创论文

    浏览:
    设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
    版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
    Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
    湘ICP备09003080号