oracle 日期处理大全文档格式.docx
《oracle 日期处理大全文档格式.docx》由会员分享,可在线阅读,更多相关《oracle 日期处理大全文档格式.docx(14页珍藏版)》请在冰豆网上搜索。
![oracle 日期处理大全文档格式.docx](https://file1.bdocx.com/fileroot1/2023-1/26/5fb43acd-2132-4388-b7c5-dbb7ac099b31/5fb43acd-2132-4388-b7c5-dbb7ac099b311.gif)
6、greatest(d1,d2,...dn)给出的日期列表中最后的日期
selectsysdateasthis_day,greatest(sysdate,sysdate+1,sysdate+2)asmax_dayfromdual;
THIS_DAYMAX_DAY
08-9月-1010-9月-10
7、least(d1,k2,...dn)给出的日期列表中最早的日期
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指定的格式转变成字符串
)astodayfromdual;
TODAY
-------------------
2010-09-0810:
37:
08
9、to_date(st[,fmt])字符串st按fmt指定的格式转成日期值,若fmt忽略,st要用缺省格式
selectto_date('
08'
)astodayfromdual;
--------------
08-9月-
1010、"
round(d[,fmt])日期d按fmt指定格式舍入到最近的日期
)asthis
round(sysdate)asround_day
to_char(sysdate+1/6,'
)asnext_4hour,round(sysdate+1/6)asround_day
fromdual;
THISROUND_DAYNEXT_4HOURROUND_DAY
------------------------------------------------------------------2010-09-0810:
52:
4508-9月-102010-09-0814:
4509-9月-
1011、"
trunc(d[,fmt])日期d按fmt指定格式截断到最近的日期
trunc(sysdate)astrunc_day
)asnext_4hour,trunc(sysdate+1/6)astrunc_day
THISTRUNC_DAYNEXT_4HOURTRUNC_DAY
56:
1808-9月-102010-09-0814:
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:
NLS_DUAL_CURRENCY$
NLS_COMPBINARY
NLS_NCHAR_CHARACTERSETZHS16GBK
NLS_RDBMS_VERSION
8."
1.
7."
0.0
或者查询V$NLS_PARAMETERS表,
select*fromV$NLS_PARAMETERS;
也有类似结果
selectto_date('
2004-11-12-07-32'
yy-mm-ddhh24-mi-ss'
)valuefromdual;
VALUE
20
4."
1
1."
1212:
07:
32
selectto_date('
'
)valuefromdual;
0."
1500:
00:
00
ERROR位于第1行:
ORA-01861:
文字与格式字符串不匹配
sysdate当前日期和时间
selectsysdatevaluefromdual;
3."
2317:
09:
01
last_day本月最后一天
selectlast_day(sysdate)valuefromdual;
3017:
08:
17
add_months(d,n)日期d后推n个月
selectadd_months(sysdate,2)valuefromdual;
5."
10:
21
next_day(d,day)日期d之后的第一周中,指定的那天(指定星期的第几天)是什么日期SQL>
selectnext_day(sysdate,1)valuefromdual;
2817:
38:
55
[oracle/plsql]oracle日期处理完全版
日期处理完全版
TO_DATE格式
Day:
ddnumber12
dyabbreviatedfri
dayspelledoutfriday
ddspthspelledout,ordinaltwelfth
Month:
mmnumber03
monabbreviatedmar
monthspelledoutmarch
Year:
yytwodigits98
yyfourdigits1998
24小时格式下时间范围为:
0:
00-23:
59:
59."
...
12小时格式下时间范围为:
1:
00-12:
59....
日期和字符转换函数用法(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('
NLS_DATE_LANGUAGE=American'
)from
dual;
monday
设置日期语言
ALTERSESSIONSETNLS_DATE_LANGUAGE='
AMERICAN'
;
也可以这样
TO_DATE('
'
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('
)andto_date('
)那么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中写
注意我这只是举了NLS_DATE_LANGUAGE,当然还有很多,
可查看
select*fromnls_session_parameters
select*fromV$NLS_PARAMETERS
8.
selectcount(*)
from(selectrownum-1rnum
fromall_objects
whererownum<
=to_date('
2002-02-28'
)-to_date('
2002-
02-01'
)+1)whereto_char(to_date('
2002-02-01'
)+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'
))"
MONTHS"
FROMDUAL;
1selectmonths_between(to_date('
02-01-1999'
1.451613
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,'
)fromall_objects;
12."
获得小时数
SELECTEXTRACT(HOURFROMTIMESTAMP'
2001-02-162:
40'
)fromoffer
selectsysdate,to_char(sysdate,'
hh'
SYSDATETO_CHAR(SYSDATE,'
HH'
-----------------------------------------
2003-10-1319:
35:
2107
hh24'
HH24'
-------------------------------------------
2119
获取____年__月__日与此类似
____年__月__日的处理
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,
older_date
from(selecthiredateolder_date,
add_months(hiredate,rownum)+rownumnewer_date
fromemp))
14."
处理月份天数不定的办法
selectto_char(add_months(last_day(sysdate)+1,-2),'
),last_day(sysdate)fromdual
16."
找出今年的天数
selectadd_months(trunc(sysdate,'
year'
),12)-trunc(sysdate,'
)fromdual闰年的处理方法
to_char(last_day(to_date('
02'
||:
year,'
mmyy'
)),'
dd'
如果是28就不是闰年
yy与rr的区别
YY99TO_C
-----------
yy990099
rr991999
yy010001
rr012001
不同时区的处理
selectto_char(NEW_TIME(sysdate,'
EST'
),'
dd/mm/yyhh:
),sysdatefromdual;
9."
5秒钟一个间隔
SelectTO_DATE(FLOOR(TO_CHAR(sysdate,'
SSS'
)/300)*300,'
),TO_CHAR(sysdate,'
fromdual
2002-11-19:
55:
0035786
SSS表示5位秒数
2
一年的第几天
selectTO_CHAR(SYSDATE,'
DDD'
),sysdatefromdual
3102002-11-610:
03:
51
计算小时,分,秒,毫秒
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)作为日.
next_day函数
next_day(sysdate,6)是从当前开始下一个星期
五。
"
后面的数字是从星期日开始算起。
很简单的一句话。
把Oracle的日期当作一个特殊数字,以天为单位。
可以进行日期+数字=日期,日期-日期=数字,日期-数字=日期
MESTAMP数据的格式化显示和DATE数据一样。
注意,to_char函数支持date和timestamp,但是trunc却不支持TIMESTAMP数据类型。
这已经清楚表明了在当两个时间的差别极度重要的情况下,使用TIMESTAMP数据类型要比DATE数据类型更确切。
如果你想显示TIMESTAMP的小数秒信息,参考下面:
1SELECTTO_CHAR(time1,'
MM/DD/YYHH24:
SS:
FF3'
)"
Date"
FROMdate_tableDate
-----------------------
06/20/200316:
14:
000
06/26/200311:
16:
36:
在上例中,我只现实了小数点后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:
00007/08/2003:
11:
22:
57:
8172
06/26/2003:
0121
这就意味着不再需要关心一天有多少秒在麻烦的计算中。
因此,得到天数、月数、天数、时数、分钟数和秒数就成为用substr函数摘取出数字的事情了。
系统日期和时间
为了得到系统时间,返回成date数据类型。
你可以使用sysdate函数。
SELECTSYSDATEFR