oracle 10g函式大全–日期型函式

點碎的陽光發表於2019-01-16
sysdate
【功能】:返回當前日期。
【引數】:沒有引數,沒有括號
【返回】:日期

【示例】select sysdate  hz from dual;
返回:2008-11-5

add_months(d1,n1)
【功能】:返回在日期d1基礎上再加n1個月後新的日期。
【引數】:d1,日期型,n1數字型
【返回】:日期

【示例】select sysdate,add_months(sysdate,3)  hz from dual;
返回:2008-11-5,2009-2-5

last_day(d1)
【功能】:返回日期d1所在月份最後一天的日期。
【引數】:d1,日期型
【返回】:日期

【示例】select sysdate,last_day(sysdate)  hz from dual;
返回:2008-11-5,2008-11-30

months_between(d1,d2)
【功能】:返回日期d1到日期d2之間的月數。
【引數】:d1,d2 日期型

【返回】:數字
如果d1>d2,則返回正數
如果d1<d2,則返回負數

【示例】
select sysdate,
months_between(sysdate,to_date(`2006-01-01`,`YYYY-MM-DD`)),
months_between(sysdate,to_date(`2016-01-01`,`YYYY-MM-DD`)) from dual;

返回:2008-11-5,34.16,-85.84

NEW_TIME(dt1,c1,c2)
【功能】:給出時間dt1在c1時區對應c2時區的日期和時間
【引數】:dt1,d2 日期型

【返回】:日期時間

【引數】:c1,c2對應的 時區及其簡寫   
  大西洋標準時間:AST或ADT   
  阿拉斯加_夏威夷時間:HST或HDT   
  英國夏令時:BST或BDT   
  美國山區時間:MST或MDT   
  美國中央時區:CST或CDT   
  新大陸標準時間:NST   
  美國東部時間:EST或EDT   
  太平洋標準時間:PST或PDT   
  格林威治標準時間:GMT   
  Yukou標準時間:YST或YDT 

【示例】
 select to_char(sysdate,`yyyy.mm.dd hh24:mi:ss`) bj_time,
to_char(new_time(sysdate,`PDT`,`GMT`),`yyyy.mm.dd hh24:mi:ss`) los_angles from dual;

返回:
BJ_TIME             LOS_ANGLES
------------------- -------------------
2008.11.05 20:11:58 2008.11.06 03:11:58

【示例】
 select sysdate bj_time,
new_time(sysdate,`PDT`,`GMT`) los_angles from dual;
返回:
BJ_TIME             LOS_ANGLES
------------------- -------------------
2008-11-05 20:11:58 2008-11-06 03:11:58

round(d1[,c1])
【功能】:給出日期d1按期間(引數c1)四捨五入後的期間的第一天日期(與數值四捨五入意思相近)
【引數】:d1日期型,c1為字元型(引數),c1預設為j(即最近0點日期)
【參數列】:c1對應的參數列:
最近0點日期: 取消引數c1或j
最近的星期日:day或dy或d
最近月初日期:month或mon或mm或rm 
最近季日期:q
最近年初日期:syear或year或yyyy或yyy或yy或y(多個y表示精度)  
最近世紀初日期:cc或scc

【返回】:日期
 
【示例】
select sysdate 當時日期,
round(sysdate) 最近0點日期,
round(sysdate,`day`) 最近星期日,
round(sysdate,`month`) 最近月初,
round(sysdate,`q`) 最近季初日期, 
round(sysdate,`year`) 最近年初日期 from dual;

trunc(d1[,c1])
【功能】:返回日期d1所在期間(引數c1)的第一天日期
【引數】:d1日期型,c1為字元型(引數),c1預設為j(即當前日期)
【參數列】:c1對應的參數列:
最近0點日期: 取消引數c1或j
最近的星期日:day或dy或d (每週順序:日,一,二,三,四,五,六)
最近月初日期:month或mon或mm或rm 
最近季日期:q
最近年初日期:syear或year或yyyy或yyy或yy或y(多個y表示精度)  
最近世紀初日期:cc或scc

【返回】:日期

【示例】
select sysdate 當時日期,
trunc(sysdate) 今天日期,
trunc(sysdate,`day`) 本週星期日,
trunc(sysdate,`month`) 本月初,
trunc(sysdate,`q`) 本季初日期, 
trunc(sysdate,`year`) 本年初日期 from dual;

next_day(d1[,c1])
【功能】:返回日期d1在下週,星期幾(引數c1)的日期
【引數】:d1日期型,c1為字元型(引數),c1預設為j(即當前日期)
【參數列】:c1對應:星期一,星期二,星期三……星期日
【返回】:日期

【示例】
select sysdate 當時日期,
next_day(sysdate,`星期一`) 下週星期一,
next_day(sysdate,`星期二`) 下週星期二,
next_day(sysdate,`星期三`) 下週星期三,
next_day(sysdate,`星期四`) 下週星期四,
next_day(sysdate,`星期五`) 下週星期五,
next_day(sysdate,`星期六`) 下週星期六,
next_day(sysdate,`星期日`) 下週星期日 from dual;

extract(c1 from d1)
【功能】:日期/時間d1中,引數(c1)的值
【引數】:d1日期型(date)/日期時間型(timestamp),c1為字元型(引數)
【參數列】:c1對應的參數列詳見示例

【返回】:字元

【示例】
select 
extract(hour from timestamp `2001-2-16 2:38:40 ` ) 小時,
extract(minute from timestamp `2001-2-16 2:38:40 ` ) 分鐘,
extract(second from timestamp `2001-2-16 2:38:40 ` ) 秒,
extract(DAY from timestamp `2001-2-16 2:38:40 ` ) 日,
extract(MONTH from timestamp `2001-2-16 2:38:40 ` ) 月,
extract(YEAR from timestamp `2001-2-16 2:38:40 ` ) 年
 from dual;

select extract (YEAR from date `2001-2-16` ) from dual; 

select sysdate 當前日期,
extract(hour from timestamp timestamp sysdate) 小時,
extract(DAY from sysdate ) 日,
extract(MONTH from sysdate ) 月,
extract(YEAR from sysdate ) 年
 from dual;
localtimestamp
【功能】:返回會話中的日期和時間 
【引數】:沒有引數,沒有括號
【返回】:日期

【示例】select localtimestamp from dual;
返回:14-11月-08 12.35.37.453000 上午

current_timestamp
【功能】:以timestamp with time zone資料型別返回當前會話時區中的當前日期
【引數】:沒有引數,沒有括號
【返回】:日期

【示例】select current_timestamp from dual;
返回:14-11月-08 12.37.34.609000 上午 +08:00

current_date
【功能】:返回當前會話時區中的當前日期 
【引數】:沒有引數,沒有括號
【返回】:日期

【示例】select current_date from dual;
返回:2008-11-14

dbtimezone
【功能】:返回時區
【引數】:沒有引數,沒有括號
【返回】:字元型

【示例】select dbtimezone from dual;

SESSIONTIMEZONE
【功能】:返回會話時區
【引數】:沒有引數,沒有括號
【返回】:字元型

【示例】select dbtimezone,SESSIONTIMEZONE from dual;
返回:+00:00   +08:00

INTERVAL c1 set1
【功能】:變動日期時間數值
【引數】:c1為數字字串或日期時間字串,set1為日期引數
【參數列】:set1具體參照示例

【返回】:日期時間格式的數值,前面多個+號
以天或天更小單位時可用數值表示式借用,如1表示1天,1/24表示1小時,1/24/60表示1分鐘

【示例】
select
trunc(sysdate)+(interval `1` second), --加1秒(1/24/60/60)
trunc(sysdate)+(interval `1` minute), --加1分鐘(1/24/60)
trunc(sysdate)+(interval `1` hour), --加1小時(1/24)
trunc(sysdate)+(INTERVAL `1` DAY),  --加1天(1)
trunc(sysdate)+(INTERVAL `1` MONTH), --加1月
trunc(sysdate)+(INTERVAL `1` YEAR), --加1年
trunc(sysdate)+(interval `01:02:03` hour to second), --加指定小時到秒
trunc(sysdate)+(interval `01:02` minute to second), --加指定分鐘到秒
trunc(sysdate)+(interval `01:02` hour to minute), --加指定小時到分鐘
trunc(sysdate)+(interval `2 01:02` day to minute) --加指定天數到分鐘
from dual;

相關文章