oracle 日期处理大全.docx
- 文档编号:10627388
- 上传时间:2023-02-22
- 格式:DOCX
- 页数:17
- 大小:20.42KB
oracle 日期处理大全.docx
《oracle 日期处理大全.docx》由会员分享,可在线阅读,更多相关《oracle 日期处理大全.docx(17页珍藏版)》请在冰豆网上搜索。
oracle日期处理大全
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,'YYYY-MM-DDHH24:
MI:
SS')aschina,
to_char(new_time(sysdate,'est','GMT'),'YYYY-MM-DDHH24:
MI:
SS')asGMT
fromdual;
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,'YYYY-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','YYYY-MM-DDHH24:
MI:
SS')astodayfromdual;
TODAY
--------------
08-9月-10
10、round(d[,fmt])日期d按fmt指定格式舍入到最近的日期
SQL>selectto_char(sysdate,'YYYY-MM-DDHH24:
MI:
SS')asthis
round(sysdate)asround_day
to_char(sysdate+1/6,'YYYY-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月-10
11、trunc(d[,fmt])日期d按fmt指定格式截断到最近的日期
SQL>selectto_char(sysdate,'YYYY-MM-DDHH24:
MI:
SS')asthis
trunc(sysdate)astrunc_day
to_char(sysdate+1/6,'YYYY-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月-10
to_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_VERSION8.1.7.0.0
或者查询V$NLS_PARAMETERS表,
select*fromV$NLS_PARAMETERS;
也有类似结果
SQL>selectto_date('2004-11-1212-07-32','yyyy-mm-ddhh24-mi-ss')valuefromdual;
VALUE
-------------------
2004.11.1212:
07:
32
SQL>selectto_date('20041015')valuefromdual;
VALUE
-------------------
2004.10.1500:
00:
00
SQL>selectto_date('20041315')valuefromdual;
ERROR位于第1行:
ORA-01861:
文字与格式字符串不匹配
sysdate当前日期和时间
SQL>selectsysdatevaluefromdual;
VALUE
-------------------
2003.11.2317:
09:
01
last_day本月最后一天
SQL>selectlast_day(sysdate)valuefromdual;
VALUE
-------------------
2003.11.3017:
08:
17
add_months(d,n)日期d后推n个月
SQL>selectadd_months(sysdate,2)valuefromdual;
VALUE
-------------------
2005.01.2317:
10:
21
next_day(d,day)日期d之后的第一周中,指定的那天(指定星期的第几天)是什么日期
SQL>selectnext_day(sysdate,1)valuefromdual;
VALUE
-------------------
2004.11.2817:
38:
55
[oracle/plsql]oracle日期处理完全版
日期处理完全版
TO_DATE格式
Day:
ddnumber12
dyabbreviatedfri
dayspelledoutfriday
ddspthspelledout,ordinaltwelfth
Month:
mmnumber03
monabbreviatedmar
monthspelledoutmarch
Year:
yytwodigits98
yyyyfourdigits1998
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','yyyy-mm-dd'),'day')fromdual;
星期一
selectto_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE=American')from
dual;
monday
设置日期语言
ALTERSESSIONSETNLS_DATE_LANGUAGE='AMERICAN';
也可以这样
TO_DATE('2002-08-26','YYYY-mm-dd','NLS_DATE_LANGUAGE=American')
4.
两个日期间的天数
selectfloor(sysdate-to_date('20020405','yyyymmdd'))fromdual;
5.时间为null的用法
selectid,active_datefromtable1
UNION
select1,TO_DATE(null)fromdual;
注意要用TO_DATE(null)
6.
a_datebetweento_date('20011201','yyyymmdd')andto_date('20011231','yyyymmdd')
那么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','yyyy-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','yyyy-mm-dd')-to_date('2002-
02-01','yyyy-mm-dd')+1
)
whereto_char(to_date('2002-02-01','yyyy-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-YYYY'),
to_date('12-31-1998','MM-DD-YYYY'))"MONTHS"FROMDUAL;
1
selectmonths_between(to_date('02-01-1999','MM-DD-YYYY'),
to_date('12-31-1998','MM-DD-YYYY'))"MONTHS"FROMDUAL;
1.03225806451613
10.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
获取年月日与此类似
13.
年月日的处理
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),'yyyymmdd'),last_day(sysdate)fromdual
16.
找出今年的天数
selectadd_months(trunc(sysdate,'year'),12)-trunc(sysdate,'year')fromdual
闰年的处理方法
to_char(last_day(to_date('02'||:
year,'mmyyyy')),'dd')
如果是28就不是闰年
17.
yyyy与rrrr的区别
'YYYY99TO_C
-----------
yyyy990099
rrrr991999
yyyy010001
rrrr012001
18.不同时区的处理
selectto_char(NEW_TIME(sysdate,'GMT','EST'),'dd/mm/yyyyhh:
mi:
ss'),sysdate
fromdual;
19.
5秒钟一个间隔
SelectTO_DATE(FLOOR(TO_CHAR(sysdate,'SSSSS')/300)*300,'SSSSS'),TO_CHAR(sysdate,'SSSSS')
fromdual
2002-11-19:
55:
0035786
SSSSS表示5位秒数
20.
一年的第几天
selectTO_CHAR(SYSDATE,'DDD'),sysdatefromdual
3102002-11-610:
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
fromdual
)
select*fromtabname
orderbydecode(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)是从当前开始下一个星期五。
后面的数字是从星期日开始算起。
很简单的一句话。
把Oracle的日期当作一个特殊数字,以天为单位。
可以进行日期+数字=日期,日期-日期=数字,日期-数字=日期
MESTAMP数据的格式化显示和DATE数据一样。
注意,to_char函数支持date和timestamp,但是trunc却不支持TIMESTAMP数据类型。
这已经清楚表明了在当两个时间的差别极度重要的情况下,使用TIMESTAMP数据类型要比DATE数据类型更确切。
如果你想显示TIMESTAMP的小数秒信息,参考下面:
1 SELECTTO_CHAR(time1,'MM/DD/YYYYHH24:
MI:
SS:
FF3')"Date"FROMdate_table
Date
-----------------------
06/20/200316:
55:
14:
000
06/26/200311:
16:
36:
000
在上例中,我只现实了小数点后3位的内容。
计算timestamp间的数据差别要比老的date数据类型更容易。
当你直接相减的话,看看会发生什么。
结果将更容易理解,第一行的17天,18小时,27分钟和43秒。
1 SELECTtime1,
2 time2,
3 substr((time2-time1),instr((time2-time1),'')+7,2) seconds,
4 substr((time2-time1),instr((time2-time1),'')+4,2) minutes,
5 substr((time2-time1),instr((time2-time1),'')+1,2) hours,
6 trunc(to_number(substr((time2-time1),1,instr(time2-time1,'
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- oracle 日期处理大全 日期 处理 大全