- Rongsen.Com.Cn 版权所有 2008-2010 京ICP备08007000号 京公海网安备11010802026356号 朝阳网安编号:110105199号
 - 北京黑客防线网安工作室-黑客防线网安服务器维护基地为您提供专业的
服务器维护
,企业网站维护
,网站维护
服务 - (建议采用1024×768分辨率,以达到最佳视觉效果) Powered by 黑客防线网安 ©2009-2010 www.rongsen.com.cn
 
 
    
        作者:黑客防线网安Oracle维护基地 来源:黑客防线网安Oracle维护基地 浏览次数:0 | 
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 
 
 日期和字符转换函数用法(to_date,to_char)
     We overwrite NLS_DATE_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
   NLS_DATE_FORMAT        DD-MON-RR
   NLS_DATE_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
| 我要申请本站:N点 | 黑客防线官网 | | 
| 专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479 |