date相關的函數

來源:互聯網
上載者:User

源時間:to_char(DateValue));
源時間減1天:to_char(DateValue-1));
源時間減1天1小時:to_char(DateValue-1-1/24));
源時間減1天1小時1分:to_char(DateValue-1-1/24-1/(24*60)));
源時間減1天1小時1分1秒:to_char(DateValue-1-1/24-1/(24*60)-1/(24*60*60)));

源時間減1月add_months(tm,-1)

oracle中處理日期大全

  TO_DATE格式 
Day: 
dd number 12 
dy abbreviated fri 
day spelled out friday 
ddspth spelled out, ordinal twelfth 
Month: 
mm number 03 
mon abbreviated mar 
month spelled out march 
Year: 
yy two digits 98 
yyyy four digits 1998 

24小時格式下時間範圍為: 0:00:00 - 23:59:59.... 
12小時格式下時間範圍為: 1:00:00 - 12:59:59 .... 
1. 
日期和字元轉換函式用法(to_date,to_char) 

2. 
select to_char( to_date(222,'J'),'Jsp') from dual 

顯示Two Hundred Twenty-Two 

3.  某天是星期幾 
select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day') from dual; 
星期一 
select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE = American') from dual; 
monday 
設定日期語言 
ALTER SESSION SET NLS_DATE_LANGUAGE='AMERICAN'; 
也可以這樣 
TO_DATE ('2002-08-26', 'YYYY-mm-dd', 'NLS_DATE_LANGUAGE = American') 

4.  兩個日期間的天數 
select floor(sysdate - to_date('20020405','yyyymmdd')) from dual; 

5. 時間為null的用法 
select id, active_date from table1 
UNION 
select 1, TO_DATE(null) from dual; 

注意要用TO_DATE(null) 

6. 
a_date between to_date('20011201','yyyymmdd') and to_date('20011231','yyyymmdd') 
那麼12月31號中午12點之後和12月1號的12點之前是不包含在這個範圍之內的。 
所以,當時間需要精確的時候,覺得to_char還是必要的 
7. 日期格式衝突問題 
輸入的格式要看你安裝的ORACLE字元集的類型, 比如: US7ASCII, date格式的類型就是: '01-Jan-01' 
alter system set NLS_DATE_LANGUAGE = American 
alter session set NLS_DATE_LANGUAGE = American 
或者在to_date中寫 
select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE = American') from dual; 
注意我這隻是舉了NLS_DATE_LANGUAGE,當然還有很多, 
可查看 
select * from nls_session_parameters 
select * from V$NLS_PARAMETERS 

8. 
select count(*) 
from ( select rownum-1 rnum 
from all_objects 
where rownum <= to_date('2002-02-28','yyyy-mm-dd') - to_date('2002- 
02-01','yyyy-mm-dd')+1 

where to_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. 
select months_between(to_date('01-31-1999','MM-DD-YYYY'), 
to_date('12-31-1998','MM-DD-YYYY')) "MONTHS" FROM DUAL; 

select months_between(to_date('02-01-1999','MM-DD-YYYY'), 
to_date('12-31-1998','MM-DD-YYYY')) "MONTHS" FROM DUAL; 

1.03225806451613 
10. Next_day的用法 
Next_day(date, day) 

Monday-Sunday, for format code DAY 
Mon-Sun, for format code DY 
1-7, for format code D 

11 
select to_char(sysdate,'hh:mi:ss') TIME from all_objects 
注意:第一條記錄的TIME 與最後一行是一樣的 
可以建立一個函數來處理這個問題 
create or replace function sys_date return date is 
begin 
return sysdate; 
end; 

select to_char(sys_date,'hh:mi:ss') from all_objects; 
12.  獲得小時數 

SELECT EXTRACT(HOUR FROM TIMESTAMP '2001-02-16 2:38:40') from offer 
select sysdate ,to_char(sysdate,'hh') from dual; 
select sysdate ,to_char(sysdate,'hh24') from dual; 

擷取年月日與此類似 
13. 年月日的處理 
select older_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 ( select hiredate older_date, 
add_months(hiredate,rownum)+rownum newer_date 
from emp ) 

14. 月份天數不定的辦法 
select to_char(add_months(last_day(sysdate) +1, -2), 'yyyymmdd'),last_day(sysdate) from dual 

15.  今年的天數 
select add_months(trunc(sysdate,'year'), 12) - trunc(sysdate,'year') from dual 

閏年的處理方法 
to_char( last_day( to_date('02' || :year,'mmyyyy') ), 'dd' ) 
如果是28就不是閏年 

16.  yyyy與rrrr的區別 
'YYYY99 TO_C 
------- ---- 
yyyy 99 0099 
rrrr 99 1999 
yyyy 01 0001 
rrrr 01 2001 

17.不同時區的處理 
select to_char( NEW_TIME( sysdate, 'GMT','EST'), 'dd/mm/yyyy hh:mi:ss') ,sysdate 
from dual; 

18.  5秒鐘一個間隔 
Select TO_DATE(FLOOR(TO_CHAR(sysdate,'SSSSS')/300) * 300,'SSSSS') ,TO_CHAR(sysdate,'SSSSS') 
from dual 

2002-11-1 9:55:00 35786 
SSSSS表示5位秒數 

19.  一年的第幾天 
select TO_CHAR(SYSDATE,'DDD'),sysdate from dual 
310 2002-11-6 10:03:51 

20.計算小時,分,秒,毫秒 
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 
from dual 

 

select * from tabname 
order by decode(mode,'FIFO',1,-1)*to_char(rq,'yyyymmddhh24miss'); 

// 
floor((date2-date1) /365) 作為年 
floor((date2-date1, 365) /30) 作為月 
mod(mod(date2-date1, 365), 30)作為日. 
21.next_day函數 
next_day(sysdate,6)是從當前開始下一個星期五。後面的數字是從星期日開始算起。 
1 2 3 4 5 6 7 
日 一 二 三 四 五 六

oracle中關於日期的函數

在oracle中有很多關於日期的函數,如:
1、add_months()用於從一個日期值增加或減少一些月份
select add_months(sysdate,12) "Next Year" from dual;
select add_months(sysdate,112) "Last Year" from dual;

2、current_date()返回當前會放時區中的當前日期
select sessiontimezone,current_date from dual;
select sessiontimezone,current_timestamp from dual;

3、current_timestamp()以timestamp with time zone資料類型返回當前會放時區中的當前日期
select sessiontimezone,current_timestamp from dual;
select sessiontimezone,current_timestamp from dual;

4、dbtimezone()返回時區
select dbtimezone from dual;

5、extract()找出日期或間隔值的欄位值
select extract(month from sysdate) "This Month" from dual;
select extract(year from add_months(sysdate,36)) "3 Years Out" from dual;

6、last_day()返回包含了日期參數的月份的最後一天的日期
select last_day(date'2000-02-01') "Leap Yr?" from dual;
select last_day(sysdate) "Last day of this month" from dual;

7、localtimestamp()返回會話中的日期和時間
select localtimestamp from dual;

select localtimestamp,current_timestamp from dual;

select localtimestamp,to_char(sysdate,'DD-MM-YYYY HH:MI:SS AM') "SYSDATE" from dual;

8、months_between()判斷兩個日期之間的月份數量
select months_between(sysdate,date'1971-05-18') from dual;
select months_between(sysdate,date'2001-01-01') from dual;

 

9、next_day()給定一個日期值,返回由第二個參數指出的日子第一次出現在的日期值(應返回相應日子的名稱字串)

與周相關日期函數

1.某周的第一天
select trunc(decode(ww, 53, to_date(yy || '3112', 'yyyyddmm'), to_date(yy || '-' || to_char(ww * 7), 'yyyy-ddd')), 'd') last_day
from (select substr('2004-32', 1, 4) yy, to_number(substr('2004-32', 6)) ww
         from dual)

select trunc(to_date(substr('2003-01',1,5)||to_char((to_number(substr('2003-01',6)))*7),'yyyy-ddd'),'d')-6 first_day from dual

select min(v_date) from
  (select (to_date('200201','yyyymm') + rownum) v_date
  from all_tables
  where rownum < 370)
where to_char(v_date,'yyyy-iw') = '2002-49'

2.某周的最後一天
select trunc(decode(ww, 53, to_date(yy || '3112', 'yyyyddmm'), to_date(yy || '-' || to_char(ww * 7), 'yyyy-ddd')), 'd') - 6 first_day
  from (select substr('2004-33', 1, 4) yy, to_number(substr('2004-33', 6)) ww
          from dual)
         
select trunc(to_date(substr('2003-01',1,5)||to_char((to_number(substr('2003-01',6)))*7),'yyyy-ddd'),'d') last_day from dual

select max(v_date) from
  (select (to_date('200408','yyyymm') + rownum) v_date
  from all_tables
  where rownum < 370)
where to_char(v_date,'yyyy-iw') = '2004-33'

3.某周的日期
select min_date, to_char(min_date,'day') day from
(select to_date(substr('2004-33',1,4)||'001'+rownum-1,'yyyyddd') min_date
        from all_tables
  where rownum <= decode(mod(to_number(substr('2004-33',1,4)),4),0,366,365) 
  union

  select to_date(substr('2004-33',1,4)-1||
         decode(mod(to_number(substr('2004-33',1,4))-1,4),0,359,358)+rownum,'yyyyddd') min_date
        from all_tables         
          where rownum <= 7
  union

  select to_date(substr('2004-33',1,4)+1||'001'+rownum-1,'yyyyddd') min_date
        from all_tables         
          where rownum <= 7                      
)
where to_char(min_date,'yyyy-iw') ='2004-33'

4.面平均計算,(group求平均、兩個時間差值:小時差,分鐘差)

--全符合條件面雨量查詢
select zc_quyu,sum(drp)/round(count(distinct(b.stcd)),3) sumrn
 from a a  ,b b
  where a.stcd=b.stcd and to_char(tm,'yyyy-mm-dd hh24:mi:ss')<='2009-08-17 16:00:00' and to_char(tm,'yyyy-mm-dd hh24:mi:ss')>='2009-08-17 0:00:00' and  to_char(tm,'miss')='0000'  and a.stcd not in(
   select stcd from a where to_char(tm,'yyyy-mm-dd hh24:mi:ss')<='2009-08-17 16:00:00' and to_char(tm,'yyyy-mm-dd hh24:mi:ss')>'2009-08-17 0:00:00' and to_char(tm,'miss')='0000' group by stcd
     having count(stcd)!=(to_date('2009-08-17 0:00:00','yyyy-mm-dd hh24:00:00')-to_date('2009-08-17 16:00:00','yyyy-mm-dd hh24:00:00') )*24
  ) group by quyu
 

時段小時差

select to_number(to_date('2006-06-20 20:34','yyyy-mm-dd hh24:mi')-to_date('2006-06-19 14:30','yyyy-mm-dd
hh24:mi'))*24 from dual;

預設時段日期差
select to_date('2006-06-20 20:34','yyyy-mm-dd hh24:mi')-to_date('2006-06-19 14:30','yyyy-mm-dd
hh24:mi') from dual;

 

本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/yfly13/archive/2010/02/08/5299103.aspx

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.