oracle日期处理全集日期加减全活儿docWord文件下载.docx
《oracle日期处理全集日期加减全活儿docWord文件下载.docx》由会员分享,可在线阅读,更多相关《oracle日期处理全集日期加减全活儿docWord文件下载.docx(14页珍藏版)》请在冰点文库上搜索。
TODAY
2010-09-0810:
37:
08
9、to_date(st字符串st按fmt指定的格式转成日期值,若fmt忽略,st要用缺省格式
selectto_date(*2010-09-0810:
087YYYY-MM-DDHH24:
SS,)astodayfromdual;
08・9月-10
10、round(d[,fmt])口期d按fmt指定格式舍入到最近的日期
)asthis,round(sysdate)asround_day
to_char(sysdate+1/6;
SSr)asnext_4hour,round(sysdate+1/6)asround_day
fromdual;
THISROUND.DAYNEXT_4HOURROUND_DAY
52:
4508-9月-102010-09-0814:
4509-9月-10
11、trunc(d[,fmt])日期d按fmt指定格式截断到最近的口期
)asthis
trunc(sysdate)astrunc_day
to_char(sysdate+1/6,'
SS*)asnext_4hour,trunc(sysdate+1/6)astrunc_day
THISTRUNC.DAYNEXT_4HOURTRUNC.DAY
56:
1808-9月-102010-09-0814:
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
NLSCALENDARGREGORIAN
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_VERSION8.1.7.0.0
或者查询V$NLS_PARAMETERS表,
select*fromV$NLS_PARAMETERS;
也有类似结果
selectto_date(*2004-l1-1212-07-32*,*yyyy-mm-ddhh24-mi-ss*)valuefromdual;
VALUE
2004」1.1212:
07:
32
selectto_date('
20041015*)valuefromdual;
2004」0」500:
00:
00
20041315'
)valuefromdual;
ERROR位于第1行:
ORA-01861:
文字与格式字符串不匹配
sysdate当前日期和时间
selectsysdatevaluefromdual;
2003.11.2317:
09:
01
last_day本月最后一天
selectlast_day(sysdate)valuefromdual;
2003.11.3017:
08:
17
add_months(d,n)日期d后推n个月
selectadd_months(sysdate,2)valuefromdual;
2005.01.2317:
10:
21next_day(d,day)日期dZ后的第一周屮,指定的那天(指定星期的第儿天)是什么日期SQL>
selectnext_day(sysdateJ)valuefromdual;
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-23:
59:
59....
12小时格式下时间范围为:
1:
00-12:
59....
1.
H期和字符转换函数用法(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.DATEC2002-08-26\'
YYYY・mm・dd;
NLS_DATE_LANGUAGE=American*)
4.
两个tl期问的天数
selectfloor(sysdate・to_date(,20020405'
yyyymmdd'
))fromdual;
5.时间为null的用法
selectid,active_datefromtable1
UNION
select1,TO_DATE(nuil)fromdual;
注意要用TO_DATE(null)
6.
a_datebetweento_date('
20011201'
yyyymmdd*)andto_date('
20011231'
/yyyymmdd'
)
那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。
所以,当时间需要精确的时候,觉得to_char还是必要的
6.日期格式冲突问题
输入的格式要看你安装的ORACLE字符集的类型,比如:
US7ASCII,date格式的类型就是:
r01-Jan-0T
altersystemsetNLS_DATE_LANGUAGE=American
altersessionsetNLS_DATE_LANGUAGE=American
或者在to_date中写
selectto_char(to_date(,2002-08-26,;
yyyy-mm-dd,);
;
NLS_DATE_LANGUAGE=American1)
from
注意我这只是举了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-017yyyy-mm-dd'
)+1
whereto_char(to_date('
2002-02-01Vyyyy-mm-dd^+mum-1,D)
not
in(T,7)
查找2002-02-28至2002-02-0II、可除星期一和七的天数
在前后分別调MDBMS_UTILITY.GET_TIME,让后将结果相减(得到的是1/100秒,而不是毫秒).
9.
selectmonths_between(to_date(,01-31-1999VMM-DD-YYYY*),
to_date('
12-31-1998'
MM-DD-YYYY'
))”MONTHS“FROMDUAL;
1
selectmonths_between(to_dateC02-01-19997MM-DD-YYYY'
),
to_date(*12-31-1998\*MM-DD-YYYY1))“MONTHS"
FROMDUAL;
1.03225806451613
7.Next_day的用法
Next_day(date,day)
Monday-Sunday,forformatcodeDAY
Mon-Sun,forformatcodeDY
1-7,forformatcodeD
11
selectto_char(sysdate/hh:
ini:
ss,)TIMEfromall_objects
注意:
第一条记录的TIME与最后一行是一样的
可以建立一个函数来处理这个问题
createorreplacefunctionsys_datereturndateis
begin
returnsysdate;
end;
selectto_char(sys_date/hh:
mi:
ssr)fromall_objects;
12.
获得小时数
SELECTEXTRACT(HOURFROMTIMESTAMP7001-02-162:
40*)fromoffer
selectsysdate,to_char(sysdate/hhr)fromdual;
SYSDATETO_CHAR(SYSDATE,'
HH'
)2003-10-1319:
35:
2107
selectsysdate,to_char(sysdate/hh24,)fromdual;
SYSDATETO_CHAR(SYSDATE,'
HH24'
2119获収年月口与此类似13.
年月Fl的处理
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),'
),last_day(sysdate)fromdual16.
找出今年的天数
selectadd_months(trunc(sysdate,ye“r'
),12)-truncCsysdate/yeaf)fromdual
闰年的处理方法
to_char(last_day(to_date(,02,||:
year,'
mmyyyy'
)),'
dd*)
如果是28就不是闰年
17.
yyyy与rrrr的区别
'
YYYY99TO_Cyyyy990099
rrrr991999
yyyy010001
rrrr012001
18.不同时区的处理
selectto_char(NEW_TIME(sysdate,GMT,EST),'
dd/mm/yyyyhh:
ss'
),sysdate
19.
5秒钟一个间隔
SelectTO_DATE(FLOOR(TO_CHAR(sysda©
SSSSS'
)/300)
300,'
),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
fromselect
trunc(sysclate)Days,
sysdate・trunc(sysdate)A
select*fromtabname
orderbydecode(mode,'
FIFO'
1,-l)*to_char(rq,'
yyyymmddhh24miss'
);
//
floor((date2-date1)/365)作为年floor((date2-date1,365)/30)作为月mod(mod(date2-datel,365),30)作为日.
23.next_day函数next_day(sysdate,6)是从当前开始下一个星期五。
后面的数字是从星期日开始算起。
很简单的一句话。
把Oracle的日期当作一个特殊数字,以天为单位。
可以进行日期+数字=H期,日期■日期二数字,日期■数字二日期
MESTAMP数据的格式化显示和DATE数据一样。
注意,to_char函数支持date和timestamp,但是trunc却不支持TIMESTAMP数据类型。
这已经清楚表明了在当两个时间的差别极度重要的情况下,使用TIMESTAMP数据类型要比DATE数据类型更确切。
如果你想显示TIMESTAMP的小数秒信息,参考下面:
1SELECTTO_CHAR(timel;
MM/DD/YYYYHH24:
SS:
FF3,)"
Date”FROMdate_table
Date
06/20/200316:
14:
000
06/26/200311:
16:
36:
在上例中,我只现实了小数点后3位的内容。
计算timestamp间的数据差别要比老的date数据类型更容易。
当你直接相减的话,看看会发生什么。
结果将更容易理解,第一行的17天,18小时,27分钟和43秒。
1SELECTtimel,
2time2,
4substr((time2-time1),instr((time2-time1)「)+4,2)minutes,
5substr((time2-time1)Jnstr((time2-time1)/*)+1,2)hours,
6trunc(to_number(substr((time2-time1),1Jnstr(time2-time1/*))))days,
7trunc(to_number(substr((time2-time1),1Jnstr(time2-timel/J))/7)weeks
8*FROMdate_table
MINUTESHOURSDAYSWEEKS
06/20/2003:
000000
2
07/08/2003:
11:
22:
57:
43
27
18
06/26/2003:
21
06
12
这就意味着不再需要关心一天有多少秒在麻烦的计算中。
因此,得到天数、月数、天数、吋数、分钟数和秒数就成为用substr函数摘取出数字的事情了。
系统口期和时间
为了得到系统时间,返回成date数据类型。
你可以使用sysdate函数。
SELECTSYSDATEFROMDUAL;
为了得到系统时间,返回成timestamp数据类型。
你可以使用systimpstamp函数。
SELECTSYSTIMESTAMPFROMDUAL;
你可以设置初始化参数FIXED_DATE指定sysdate函数返回一个固定值。
这用在测试日期和时间敏感的代码。
注意,这个参数对于systimestamp函数无效。
ALTERSYSTEMSETfixed_date='
2003-01-01-10:
00'
Systemaltered.
selectsysdatefromdual;
SYSDATE
01-JAN-03
selectsystimestampfromdual;
SYSTIMESTAMP
09-JUL-0311.05.02.519000AM-06:
当使用date和timestamp类型的时候,选择是很清楚的。
你可以随意处置date和timestamp类型。
当你试图转换到更强大的timestamp的时候,需要注意,它们既有类似的地方,更有不同的地方,而足以造成破坏。
两者在简洁和间隔尺寸方面各有优势,请合理地选择。
DateDiff(month,waterpay.CopyDate,GetDate())=1)
DateDiff(day,WaterPay.CopyDate,GetDate())=1)
这两个句子的意思分别是:
求以month或者以day的方式返回当前日期(getdate)减数据库屮的一个日期字段(waterpay.CopyDate)的值等于1的记录