oracle 日期处理大全Word文件下载.docx
- 文档编号:17666989
- 上传时间:2022-12-08
- 格式:DOCX
- 页数:15
- 大小:20.48KB
oracle 日期处理大全Word文件下载.docx
《oracle 日期处理大全Word文件下载.docx》由会员分享,可在线阅读,更多相关《oracle 日期处理大全Word文件下载.docx(15页珍藏版)》请在冰豆网上搜索。
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('
2010-09-0810:
08'
--------------
08-9月-10
10、round(d[,fmt])日期d按fmt指定格式舍入到最近的日期
)asthis
round(sysdate)asround_day
to_char(sysdate+1/6,'
)asnext_4hour
round(sysdate+1/6)asround_day
THISROUND_DAYNEXT_4HOURROUND_DAY
------------------------------------------------------------------
52:
4508-9月-102010-09-0814:
4509-9月-10
11、trunc(d[,fmt])日期d按fmt指定格式截断到最近的日期
trunc(sysdate)astrunc_day
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
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_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
20041015'
2004.10.1500:
00:
00
20041315'
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:
21
next_day(d,day)日期d之后的第一周中,指定的那天(指定星期的第几天)是什么日期
selectnext_day(sysdate,1)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.
日期和字符转换函数用法(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;
星期一
NLS_DATE_LANGUAGE=American'
)from
dual;
monday
设置日期语言
ALTERSESSIONSETNLS_DATE_LANGUAGE='
AMERICAN'
;
也可以这样
TO_DATE('
'
YYYY-mm-dd'
)
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'
)andto_date('
20011231'
那么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-YYYY'
),
to_date('
12-31-1998'
))"
MONTHS"
FROMDUAL;
1
02-01-1999'
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,'
)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
获取年月日与此类似
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,
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,'
闰年的处理方法
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,'
EST'
),'
dd/mm/yyyyhh:
),sysdate
fromdual;
19.
5秒钟一个间隔
SelectTO_DATE(FLOOR(TO_CHAR(sysdate,'
SSSSS'
)/300)*300,'
),TO_CHAR(sysdate,'
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
(
trunc(sysdate)Days,
sysdate-trunc(sysdate)A
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:
SS:
FF3'
)"
Date"
FROMdate_table
Date
-----------------------
06/20/200316:
14:
000
06/26/200311:
16:
36:
在上例中,我只现实了小数点后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 日期处理大全 日期 处理 大全