oracle 日期处理大全.docx
《oracle 日期处理大全.docx》由会员分享,可在线阅读,更多相关《oracle 日期处理大全.docx(14页珍藏版)》请在冰豆网上搜索。
oracle日期处理大全
oracle日期处理大全.txt你无法改变别人,但你可以改变自己;你无法改变天气,但你可以改变心情;你无法改变生命长度,但你可以拓展它的宽度。
oracle日期处理大全.txt18拥有诚实,就舍弃了虚伪;拥有诚实,就舍弃了无聊;拥有踏实,就舍弃了浮躁,不论是有意的丢弃,还是意外的失去,只要曾经真实拥有,在一些时候,大度舍弃也是一种境界。
oracle日期函数网上已经有了不少,特我们跟集中一下,免得大家麻烦。
在oracle数据库的开发中,常因为时间的问题大费周章,所以特地将ORACLE数据的日期函数收藏致此。
乃供他日所查也。
1、add_months(d,n)日期d加n个月
SQL>SELECTSYSDATEASThis_Day,add_months(SYSDATE,1)ASNext_DayFROMdual;THIS_DAYNEXT_DAY
--------------------------
08-9月-1008-10月-10
2、last_day(d)包含d的月份的最后一天的日期
SQL>selectlast_day(sysdate)aslast_dayfromdual;
LAST_DAY
-----------
30-9月-10
3、new_time(d,a,b)时区的日期和时间d在b时区的日期和时间
SQL>selectto_char(sysdate,'YY-MM-DDHH24:
MI:
SS')aschina,
to_char(new_time(sysdate,'est','GMT'),'YY-MM-DDHH24:
MI:
SS')asGMTfromdual;
CHINAGMT
--------------------------------------
2010-09-0809:
51:
502010-09-0814:
51:
50
4、next_day(d,day)比日期d晚,由day指定的周几的日期
SQL>selectsysdateasthis_day,next_day(sysdate,7)asnext_satfromdual;THIS_DAYNEXT_SAT
----------------------------
08-9月-1011-9月-10
5、sysdate当前的系统日期和时间
6、greatest(d1,d2,...dn)给出的日期列表中最后的日期
SQL>selectsysdateasthis_day,greatest(sysdate,sysdate+1,sysdate+2)asmax_dayfromdual;
THIS_DAYMAX_DAY
----------------------------
08-9月-1010-9月-10
7、least(d1,k2,...dn)给出的日期列表中最早的日期
SQL>selectsysdateasthis_day,least(sysdate,sysdate+1,sysdate-1)asmin_dayfromdual;
THIS_DAYMIN_DAY
----------------------------
08-9月-1007-9月-10
8、to_char(d[,fmt])日期d按fmt指定的格式转变成字符串
SQL>selectto_char(sysdate,'YY-MM-DDHH24:
MI:
SS')astodayfromdual;TODAY
-------------------
2010-09-0810:
37:
08
9、to_date(st[,fmt])字符串st按fmt指定的格式转成日期值,若fmt忽略,st要用缺省格式
SQL>selectto_date('2010-09-0810:
37:
08','YY-MM-DDHH24:
MI:
SS')astodayfromdual;
TODAY
--------------
08-9月-
1010、"round(d[,fmt])日期d按fmt指定格式舍入到最近的日期
SQL>selectto_char(sysdate,'YY-MM-DDHH24:
MI:
SS')asthis
round(sysdate)asround_day
to_char(sysdate+1/6,'YY-MM-DDHH24:
MI:
SS')asnext_4hour,round(sysdate+1/6)asround_day
fromdual;
THISROUND_DAYNEXT_4HOURROUND_DAY
------------------------------------------------------------------2010-09-0810:
52:
4508-9月-102010-09-0814:
52:
4509-9月-
1011、"trunc(d[,fmt])日期d按fmt指定格式截断到最近的日期
SQL>selectto_char(sysdate,'YY-MM-DDHH24:
MI:
SS')asthis
trunc(sysdate)astrunc_day
to_char(sysdate+1/6,'YY-MM-DDHH24:
MI:
SS')asnext_4hour,trunc(sysdate+1/6)astrunc_day
fromdual;
THISTRUNC_DAYNEXT_4HOURTRUNC_DAY
------------------------------------------------------------------2010-09-0810:
56:
1808-9月-102010-09-0814:
56:
1808-9月-10to_date字符串类型转为换日期类型
字符串中的相应位置上的字符,必须符合时间范围的限制
查询Oracle日期格式
----------------------------------
select*fromnls_database_parameters;
得到结果如下表:
表中NLS_DATE_FORMAT表示日期格式.
PARAMETERVALUE
----------------------------------------------------------------------NLS_LANGUAGEAMERICAN
NLS_TERRITORYAMERICA
NLS_CURRENCY$
NLS_ISO_CURRENCYAMERICA
NLS_NUMERIC_CHARACTERS.,
NLS_CHARACTERSETZHS16GBK
NLS_CALENDARGREGORIAN
NLS_DATE_FORMATDD-MON-RR
NLS_DATE_LANGUAGEAMERICAN
NLS_SORTBINARY
NLS_TIME_FORMATHH.MI.SSXFFAM
NLS_TIMESTAMP_FORMATDD-MON-RRHH.MI.SSXFFAM
NLS_TIME_TZ_FORMATHH.MI.SSXFFAMTZH:
TZM
NLS_TIMESTAMP_TZ_FORMATDD-MON-RRHH.MI.SSXFFAMTZH:
TZM
NLS_DUAL_CURRENCY$
NLS_COMPBINARY
NLS_NCHAR_CHARACTERSETZHS16GBK
NLS_RDBMS_VERSION
8."
1.
7."
0.0
或者查询V$NLS_PARAMETERS表,
select*fromV$NLS_PARAMETERS;
也有类似结果
SQL>selectto_date('2004-11-12-07-32','yy-mm-ddhh24-mi-ss')valuefromdual;VALUE
-------------------
20
0
4."1
1."1212:
07:
32
SQL>selectto_date('')valuefromdual;
VALUE
-------------------
20
0
4."1
0."1500:
00:
00
SQL>selectto_date('')valuefromdual;
ERROR位于第1行:
ORA-01861:
文字与格式字符串不匹配
sysdate当前日期和时间
SQL>selectsysdatevaluefromdual;
VALUE
-------------------
20
0
3."1
1."2317:
09:
01
last_day本月最后一天
SQL>selectlast_day(sysdate)valuefromdual;
VALUE
-------------------
20
0
3."1
1."3017:
08:
17
add_months(d,n)日期d后推n个月
SQL>selectadd_months(sysdate,2)valuefromdual;
VALUE
-------------------
20
0
5."0
1."2317:
10:
21
next_day(d,day)日期d之后的第一周中,指定的那天(指定星期的第几天)是什么日期SQL>selectnext_day(sysdate,1)valuefromdual;
VALUE
-------------------
20
0
4."1
1."2817:
38:
55
[oracle/plsql]oracle日期处理完全版
日期处理完全版
TO_DATE格式
Day:
ddnumber12
dyabbreviatedfri
dayspelledoutfriday
ddspthspelledout,ordinaltwelfth
Month:
mmnumber03
monabbreviatedmar
monthspelledoutmarch
Year:
yytwodigits98
yyfourdigits1998
24小时格式下时间范围为:
0:
00:
00-23:
59:
59."...
12小时格式下时间范围为:
1:
00:
00-12:
59:
59....
1.
日期和字符转换函数用法(to_date,to_char)
2.
selectto_char(to_date(222,'J'),'Jsp')fromdual
显示TwoHundredTwenty-Two
3.
求某天是星期几
selectto_char(to_date('2002-08-26','yy-mm-dd'),'day')fromdual;
星期一
selectto_char(to_date('2002-08-26','yy-mm-dd'),'day','NLS_DATE_LANGUAGE=American')from
dual;
monday
设置日期语言
ALTERSESSIONSETNLS_DATE_LANGUAGE='AMERICAN';
也可以这样
TO_DATE('2002-08-26','YY-mm-dd','NLS_DATE_LANGUAGE=American')
4.
两个日期间的天数
selectfloor(sysdate-to_date('','yymmdd'))fromdual;
5.时间为null的用法
selectid,active_datefromtable1
UNION
select1,TO_DATE(null)fromdual;
注意要用TO_DATE(null)
6.
a_datebetweento_date('','yymmdd')andto_date('','yymmdd')那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。
所以,当时间需要精确的时候,觉得to_char还是必要的
7.日期格式冲突问题
输入的格式要看你安装的ORACLE字符集的类型,比如:
US7ASCII,date格式的类型就是:
'01-Jan-01'
altersystemsetNLS_DATE_LANGUAGE=American
altersessionsetNLS_DATE_LANGUAGE=American
或者在to_date中写
selectto_char(to_date('2002-08-26','yy-mm-dd'),'day','NLS_DATE_LANGUAGE=American')from
dual;
注意我这只是举了NLS_DATE_LANGUAGE,当然还有很多,
可查看
select*fromnls_session_parameters
select*fromV$NLS_PARAMETERS
8.
selectcount(*)
from(selectrownum-1rnum
fromall_objects
whererownum<=to_date('2002-02-28','yy-mm-dd')-to_date('2002-
02-01','yy-mm-dd')+1)whereto_char(to_date('2002-02-01','yy-mm-dd')+rnum-1,'D')
not
in('1','7')
查找2002-02-28至2002-02-01间除星期一和七的天数
在前后分别调用DBMS_UTILITY.GET_TIME,让后将结果相减(得到的是1/100秒,而不是毫秒).
9.
selectmonths_between(to_date('01-31-1999','MM-DD-YY'),
to_date('12-31-1998','MM-DD-YY'))"MONTHS"FROMDUAL;1selectmonths_between(to_date('02-01-1999','MM-DD-YY'),
to_date('12-31-1998','MM-DD-YY'))"MONTHS"FROMDUAL;
1.451613
1
0."Next_day的用法
Next_day(date,day)
Monday-Sunday,forformatcodeDAY
Mon-Sun,forformatcodeDY
1-7,forformatcodeD
11
selectto_char(sysdate,'hh:
mi:
ss')TIMEfromall_objects
注意:
第一条记录的TIME与最后一行是一样的
可以建立一个函数来处理这个问题
createorreplacefunctionsys_datereturndateis
begin
returnsysdate;
end;
selectto_char(sys_date,'hh:
mi:
ss')fromall_objects;
12."
获得小时数
SELECTEXTRACT(HOURFROMTIMESTAMP'2001-02-162:
38:
40')fromoffer
SQL>selectsysdate,to_char(sysdate,'hh')fromdual;
SYSDATETO_CHAR(SYSDATE,'HH')
-----------------------------------------
2003-10-1319:
35:
2107
SQL>selectsysdate,to_char(sysdate,'hh24')fromdual;
SYSDATETO_CHAR(SYSDATE,'HH24')
-------------------------------------------
2003-10-1319:
35:
2119
获取____年__月__日与此类似
1
3."
____年__月__日的处理
selectolder_date,
newer_date,
years,
months,
abs(
trunc(
newer_date-
add_months(older_date,years*12+months)))days
from(select
trunc(months_between(newer_date,older_date)/12)YEARS,
mod(trunc(months_between(newer_date,older_date)),
12)MONTHS,
newer_date,
older_date
from(selecthiredateolder_date,
add_months(hiredate,rownum)+rownumnewer_date
fromemp))
14."
处理月份天数不定的办法
selectto_char(add_months(last_day(sysdate)+1,-2),'yymmdd'),last_day(sysdate)fromdual
16."
找出今年的天数
selectadd_months(trunc(sysdate,'year'),12)-trunc(sysdate,'year')fromdual闰年的处理方法
to_char(last_day(to_date('02'||:
year,'mmyy')),'dd')
如果是28就不是闰年
1
7."
yy与rr的区别
'YY99TO_C
-----------
yy990099
rr991999
yy010001
rr012001
1
8."不同时区的处理
selectto_char(NEW_TIME(sysdate,'GMT','EST'),'dd/mm/yyhh:
mi:
ss'),sysdatefromdual;
1
9."
5秒钟一个间隔
SelectTO_DATE(FLOOR(TO_CHAR(sysdate,'SSS')/300)*300,'SSS'),TO_CHAR(sysdate,'SSS')
fromdual
2002-11-19:
55:
0035786
SSS表示5位秒数
2
0."
一年的第几天
selectTO_CHAR(SYSDATE,'DDD'),sysdatefromdual
3102002-11-610:
03:
51
2
1."计算小时,分,秒,毫秒
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
fromdual)select*fromtabname
orderbydecode(mode,'FIFO',1,-1)*to_char(rq,'yymmddhh24miss');
//
floor((date2-date1)/365)作为年
floor((date2-date1,365)/30)作为月
mod(mod(date2-date1,365),30)作为日.
2
3."next_day函数
next_day(sysdate,6)是从当前开始下一个星期
五。
"后面的数字是从星期日开始算起。
很简单的一句话。
把Oracle的日期当作一个特殊数字,以天为单位。
可以进行日期+数字=日期,日期-日期=数字,日期-数字=日期
MESTAMP数据的格式化显示和DATE数据一样。
注意,to_char函数支持date和timestamp,但是trunc却不支持TIMESTAMP数据类型。
这已经清楚表明了在当两个时间的差别极度重要的情况下,使用TIMESTAMP数据类型要比DATE数据类型更确切。
如果你想显示TIMESTAMP的小数秒信息,参考下面:
1SELECTTO_CHAR(time1,'MM/DD/YYHH24:
MI:
SS:
FF3')"Date"FROMdate_tableDate
-----------------------
06/20/200316:
55:
14:
000
06/26/200311:
16:
36:
000
在上例中,我只现实了小数点后3位的内容。
计算timestamp间的数据差别要比老的date数据类型更容易。
当你直接相减的话,看看会发生什么。
结果将更容易理解,第一行的17天,18小时,27分钟和43秒。
1SELECTtime1,
2time2,
3substr((time2-time1),instr((time2-time1),'')+7,2)seconds,
4substr((time2-time1),instr((time2-time1),'')+4,2)minutes,
5substr((time2-time1),instr((time2-time1),'')+1,2)hours,
6trunc(to_number(substr((time2-time1),1,instr(time2-time1,''))))days,
7trunc(to_number(substr((time2-time1),1,instr(time2-time1,'')))/7)weeks
8*FROMdate_table
TIME1TIME2SECONDSMINUTESHOURSDAYSWEEKS
-------------------------------------------------------------------------------
06/20/2003:
16:
55:
14:
00007/08/2003:
11:
22:
57:
8172
06/26/2003:
11:
16:
36:
00007/08/2003:
11:
22:
57:
0121
这就意味着不再需要关心一天有多少秒在麻烦的计算中。
因此,得到天数、月数、天数、时数、分钟数和秒数就成为用substr函数摘取出数字的事情了。
系统日期和时间
为了得到系统时间,返回成date数据类型。
你可以使用sysdate函数。
SQL>SELECTSYSDATEFR