当前位置:文档之家› Oracle的to_date函数

Oracle的to_date函数

Oracle的to_date函数日期格式参数含义说明D一周中的星期几DAY天的名字,使用空格填充到9个字符DD月中的第几天DDD年中的第几天DY天的简写名IW ISO标准的年中的第几周IYYYISO标准的四位年份YY四位年份YYY,YY,Y年份的最后三位,两位,一位HH小时,按12小时计HH24小时,按24小时计MI分SS秒MM月Mon月份的简写注:在不同的语言下显示出来的数据不同,在中文下显示为5月,在英文下显示为MAYMonth月份的全名W该月的第几个星期WW年中的第几个星期1.日期时间间隔操作当前时间减去7分钟的时间select sysdate,sysdate -interval ’7’ MINUTE from dual 当前时间减去7小时的时间select sysdate -interval ’7’ hour from dual当前时间减去7天的时间select sysdate - interval ’7’ day from dual当前时间减去7月的时间select sysdate,sysdate -interval ’7’ month from dual 当前时间减去7年的时间select sysdate,sysdate -interval ’7’ year from dual时间间隔乘以一个数字select sysdate,sysdate -8 *interval ’2’ hour from dual 2.日期到字符操作select sysdate,to_char(sysdate,’y y-mm-dd hh24:mi: ss’) from dualselect sysdate,to_char(sysdate,’yy-mm-dd hh:mi:ss’) from dualselect sysdate,to_char(sysdate,’yy-ddd hh:mi:ss’) from dualselect sysdate,to_char(sysdate,’yy-mm iw-d hh:mi:ss’) from dual参考oracle的相关关文档(ORACLE901DOC/SERVER.901/A90125/SQL_ELEMENTS4."HTM#48515)03.字符到日期操作select to_date(’2003-10-17 21:15:37’,’yy-mm-dd hh24:mi:ss’) from dual具体用法和上面的to_char差不多。

4. trunk/ ROUND函数的使用select trunc(sysdate ,’YEAR’) from dualselect trunc(sysdate ) from dualselect to_char(trunc(sysdate ,’YY’),’YY’) from dual5.oracle有毫秒级的数据类型--返回当前时间____年__月__日小时分秒毫秒select to_char(current_timestamp(5),’DD-MON-YYHH24:MI:SSxFF’) from dual;--返回当前时间的秒毫秒,可以指定秒后面的精度(最大=9) select to_char(current_timestamp(9),’MI:S SxFF’) from dual;6.计算程序运行的时间(ms)declaretype rc is ref cursor;l_rc rc;l_dummy all_objects.object_name%type;l_start number default dbms_utility.get_time; beginfor I in 1 .. 1000loopopen l_rc for’select object_name from all_objects ’||’where object_id = ’ || i;fetch l_rc into l_dummy;close l_rc;end loop;dbms_output.put_line( round( (dbms_utility.get_time-l_start)/100, 2 ) || ’ seconds...’ );end;================================================================= ===============1.日期和字符转换函数用法(to_date,to_char)2.select to_char( to_date(222,'J'),'Jsp') from dual(这个经典....)显示Two Hundred Twenty-Two3.求某天是星期几select to_char(to_date('2002-08-26','yy-mm-dd'),'day') from dual;星期一selectto_char(to_date('2002-08-26','yy-mm-dd'),'day','NLS_DATE_LANGUAGE=American')from dual;monday设置日期语言ALTER SESSION SET NLS_DATE_LANGUAGE='AMERICAN';1也可以这样TO_DATE('2002-08-26','YY-mm-dd','NLS_DATE_LANGUAGE=American')4.两个日期间的天数select floor(sysdate - to_date('','yymmdd')) from dual;5.时间为null的用法select id, active_date from table1UNIONselect 1, TO_DATE(null) from dual;注意要用TO_DATE(null)6.a_date between to_date('','yymmdd') and to_date('','yymmdd')那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。

所以,当时间需要精确的时候,觉得to_char还是必要的7.日期格式冲突问题输入的格式要看你安装的ORACLE字符集的类型,比如:US7ASCII,date格式的类型就是:'01-Jan-01'alter system set NLS_DATE_LANGUAGE = Americanalter session set NLS_DATE_LANGUAGE = American或者在to_date中写selectto_char(to_date('2002-08-26','yy-mm-dd'),'day','NLS_DATE_LANGUAGE=American')fromdual;注意我这只是举了NLS_DATE_LANGUAGE,当然还有很多,可查看select * from nls_session_parametersselect * from V$NLS_PARAMETERS8. select count(*)from ( select rownum-1 rnum from all_objectswhere rownum <= to_date('2002-02-28','yy-mm-dd') - to_date('2002-02-01','yy-mm-dd')+1 )where to_char( to_date('2002-02-01','yy-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-YY'),to_date('12-31-1998','MM-DD-YY')) "MONTHS" FROM DUAL;1select months_between(to_date('02-01-1999','MM-DD-YY'),to_date('12-31-1998','MM-DD-YY')) "MONTHS" FROM DUAL;1.." Next_day的用法Next_day(date, day)Monday-Sunday, for format code DAYMon-Sun, for format code DY1-7, for format codeD11."select to_char(sysdate,'hh:mi:ss') TIME from all_objects注意:第一条记录的TIME与最后一行是一样的2可以建立一个函数来处理这个问题create or replace function sys_date return date isbeginreturn sysdate;end;select to_char(sys_date,'hh:mi:ss') from all_objects;12."获得小时数SELECT EXTRACT(HOUR FROM TIMESTAMP '2001-02-162:38:40') fromofferSQL> select sysdate ,to_char(sysdate,'hh') from dual;SYSDATE TO_CHAR(SYSDATE,'HH')-------------------- ---------------------2003-10-13 19:35:21 07SQL> select sysdate ,to_char(sysdate,'hh24') from dual; SYSDATE TO_CHAR(SYSDATE,'HH24')-------------------- -----------------------2003-10-13 19:35:21 19获取____年__月__日与此类似13."____年__月__日的处理select older_date,newer_date,years,months,abs(trunc(newer_date-add_months( older_date,years*12+months ))) daysfrom ( selecttrunc(months_between( newer_date, older_date )/12) YEARS, mod(trunc(months_between( newer_date, older_date )),12 ) MONTHS,newer_date,older_datefrom ( select hiredate older_date,add_months(hiredate,rownum)+rownum newer_datefrom emp ))14."处理月份天数不定的办法selectto_char(add_months(last_day(sysdate)+1,-2),'yymmdd'),last_day(sysdate) from dual15."找出今年的天数selectadd_months(trunc(sysdate,'year'),12)-trunc(sysdate,'year')fromdual3闰年的处理方法to_char( last_day( to_date('02' || :year,'mmyy') ), 'dd' )如果是28就不是闰年16."yy与rr的区别'YY99 TO_C------- ----yy 99 0099rr 99 1999yy 01 0001rr 01200117."不同时区的处理selectto_char(NEW_TIME(sysdate,'GMT','EST'),'dd/mm/yyhh:mi:ss') ,sysdatefrom dual;18."5秒钟一个间隔SelectTO_DATE(FLOOR(TO_CHAR(sysdate,'SSS')/300)*300,'SSS') ,TO_CHAR(sysdate,'S SS')from dual2002-11-1 9:55:00 35786SSS表示5位秒数19."一年的第几天select TO_CHAR(SYSDATE,'DDD'),sysdate from dual310 2002-11-6 10:03:5120."计算小时,分,秒,毫秒selectDays,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)) mSecondsfrom(selecttrunc(sysdate) Days,sysdate - trunc(sysdate) Afrom dual)select * from tabnameorder by decode(mode,'FIFO',1,-1)*to_char(rq,'yymmddhh24miss');//floor((date2-date1) /365)作为年floor((date2-date1, 365) /30)作为月mod(mod(date2-date1, 365), 30)作为日.21."next_day函数4next_day(sysdate,6)是从当前开始下一个星期五。

相关主题