在Oracle中實現各種日期處理(1)
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','NL2006-3-22_LANGUAGE = American') from dual;
monday
設定日期語言
ALTER SESSION SET NL2006-3-22_LANGUAGE='AMERICAN';
也可以這樣
TO_DATE ('2002-08-26', 'YYYY-mm-dd', 'NL2006-3-22_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 NL2006-3-22_LANGUAGE = American
alter session set NL2006-3-22_LANGUAGE = American
或者在to_date中寫
select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NL2006-3-22_LANGUAGE = American') from dual;
注意我這只是舉了NL2006-3-22_LANGUAGE,當然還有很多,
可檢視
select * from nls_session_parameters
select * from V$NLS_PARAMETERS
日期和字元轉換函式用法(to_date,to_char)
We overwrite NL2006-3-22_FORMAT into different formats for the session.
SQL> alter session set nls_date_format = 'DD-MON-RR'; Session altered.
SQL> set pagesize 0
SQL> set linesize 130
SQL> select * from nls_session_parameters;
NLS_LANGUAGE AMERICAN
NLS_TERRITORY AMERICA
NLS_CURRENCY $
NLS_ISO_CURRENCY AMERICA
NLS_NUMERIC_CHARACTERS .,
NLS_CALENDAR GREGORIAN
NL2006-3-22_FORMAT DD-MON-RR
NL2006-3-22_LANGUAGE AMERICAN
NLS_SORT BINARY
NLS_TIME_FORMAT HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT HH.MI.SSXFF AM TZH:TZM
NLS_TIMESTAMP_TZ_FORMAT DD-MON-RR HH.MI.SSXFF AM TZH:TZM
NLS_DUAL_CURRENCY $
NLS_COMP BINARY
15 rows selected.
specify it in SQL statement:
SQL> select to_date('03-SEP-1999','DD-MON-YYYY') from dual;
03-SEP-99
SQL> alter session set nls_date_format = 'MM-DD-YYYY';
Session altered.
SQL> select to_date('03-SEP-99','DD-MON-YY') from dual;
TO_DATE('0
----------
09-03-1999
SQL> alter session set nls_date_format = 'RRRR-MM-DD';
Session altered.
SQL> select to_date('03-SEP-1999','DD-MON-YYYY') from dual;
TO_DATE('0
----------
1999-09-03
When we use TO_CHAR function, we get expected results of format from current SQL statement:
SQL> alter session set nls_date_format = 'MM-DD-YY';
Session altered.
SQL> select to_char(sysdate,'dd-mm-yyyy') from dual;
TO_CHAR(SYSDATE,'DD-MM-YYYY')
07-09-1999
SQL> alter session set nls_date_format = 'RR-MON-DD';
Session altered.
SQL> select to_char(sysdate,'dd-mon-yy') from dual;
TO_CHAR(SYSDATE,'DD-MON-YY')
07-sep-99
SQL> select to_char(sysdate,'dd-Mon-yy') from dual;
TO_CHAR(SYSDATE,'DD-MON-YY')
07-Sep-99
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秒, 而不是毫秒).
[@more@]
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','NL2006-3-22_LANGUAGE = American') from dual;
monday
設定日期語言
ALTER SESSION SET NL2006-3-22_LANGUAGE='AMERICAN';
也可以這樣
TO_DATE ('2002-08-26', 'YYYY-mm-dd', 'NL2006-3-22_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 NL2006-3-22_LANGUAGE = American
alter session set NL2006-3-22_LANGUAGE = American
或者在to_date中寫
select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NL2006-3-22_LANGUAGE = American') from dual;
注意我這只是舉了NL2006-3-22_LANGUAGE,當然還有很多,
可檢視
select * from nls_session_parameters
select * from V$NLS_PARAMETERS
日期和字元轉換函式用法(to_date,to_char)
We overwrite NL2006-3-22_FORMAT into different formats for the session.
SQL> alter session set nls_date_format = 'DD-MON-RR'; Session altered.
SQL> set pagesize 0
SQL> set linesize 130
SQL> select * from nls_session_parameters;
NLS_LANGUAGE AMERICAN
NLS_TERRITORY AMERICA
NLS_CURRENCY $
NLS_ISO_CURRENCY AMERICA
NLS_NUMERIC_CHARACTERS .,
NLS_CALENDAR GREGORIAN
NL2006-3-22_FORMAT DD-MON-RR
NL2006-3-22_LANGUAGE AMERICAN
NLS_SORT BINARY
NLS_TIME_FORMAT HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT HH.MI.SSXFF AM TZH:TZM
NLS_TIMESTAMP_TZ_FORMAT DD-MON-RR HH.MI.SSXFF AM TZH:TZM
NLS_DUAL_CURRENCY $
NLS_COMP BINARY
15 rows selected.
specify it in SQL statement:
SQL> select to_date('03-SEP-1999','DD-MON-YYYY') from dual;
03-SEP-99
SQL> alter session set nls_date_format = 'MM-DD-YYYY';
Session altered.
SQL> select to_date('03-SEP-99','DD-MON-YY') from dual;
TO_DATE('0
----------
09-03-1999
SQL> alter session set nls_date_format = 'RRRR-MM-DD';
Session altered.
SQL> select to_date('03-SEP-1999','DD-MON-YYYY') from dual;
TO_DATE('0
----------
1999-09-03
When we use TO_CHAR function, we get expected results of format from current SQL statement:
SQL> alter session set nls_date_format = 'MM-DD-YY';
Session altered.
SQL> select to_char(sysdate,'dd-mm-yyyy') from dual;
TO_CHAR(SYSDATE,'DD-MM-YYYY')
07-09-1999
SQL> alter session set nls_date_format = 'RR-MON-DD';
Session altered.
SQL> select to_char(sysdate,'dd-mon-yy') from dual;
TO_CHAR(SYSDATE,'DD-MON-YY')
07-sep-99
SQL> select to_char(sysdate,'dd-Mon-yy') from dual;
TO_CHAR(SYSDATE,'DD-MON-YY')
07-Sep-99
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秒, 而不是毫秒).
[@more@]
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/18921899/viewspace-1017195/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 在Oracle中實現各種日期處理(2)Oracle
- 在Oracle中實現各種日期處理完全版Oracle
- 在oracle中處理日期Oracle
- java日期時間各種變換及處理Java
- Oracle非法日期 處理方案Oracle
- oracle日期處理集錦Oracle
- 各種報錯處理方法
- MySQL中處理各種重複的一些方法MySql
- Oracle 中的 TO_DATE 和 TO_CHAR 函式 日期處理Oracle函式
- JDBC中Date日期物件的處理JDBC物件
- Calendar類在Java中的應用與日期時間處理Java
- Scala日期處理
- JavaUtils - 日期處理Java
- java(日期處理)Java
- Hive 日期處理Hive
- echart 各種圖實現
- 關於Python中的日期處理Python
- TaroEcharts-各種圖表在Taro中的實踐Echarts
- 在Struts中如何處理ActionForm中包含日期型別屬性的情況ORM型別
- ORACLE分散式事務鎖各種場景下的處理詳解Oracle分散式
- oracle redo各種狀態(inactive、active、current)損壞的處理方式Oracle Redo
- SQL Server各種日期計算方法SQLServer
- 數字影像處理--認識影像各種概念
- 相親交友原始碼開發中會用到的幾種日期處理方法原始碼
- 商業銀行在CNAPS體系中對各種交易的處理
- jstl處理日期JS
- 水庫斷面水位中--水勢顯示效果處理--日期處理 SQLSQL
- WMI Series 1:實現Windows管理的各種技術概述 (轉)Windows
- 總結logminer使用及各種問題處理
- 無備份恢復各種場景的處理
- 使用Apache POI 處理Miscrosoft Office各種格式檔案ApacheROS
- Oracle中Date的各種格式轉換Oracle
- [工具]PHP 中的日期時間處理利器 – CarbonPHP
- [工具]PHP 中的日期時間處理利器 - CarbonPHP
- 單例模式的各種實現單例模式
- CSS居中的各種實現方式CSS
- 在struts2框架中實現手動處理輸入驗證框架
- JSP 日期處理概述JS