《2022年ORACLE时间函数 .pdf》由会员分享,可在线阅读,更多相关《2022年ORACLE时间函数 .pdf(16页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、ORACLE 时间函数 : sysdate+(5/24/60/60) 在系统时间基础上延迟5 秒sysdate+5/24/60 在系统时间基础上延迟5 分钟sysdate+5/24 在系统时间基础上延迟5 小时sysdate+5 在系统时间基础上延迟5 天add_months(sysdate,-5) 在系统时间基础上延迟5 月add_months(sysdate,-5*12) 在系统时间基础上延迟5 年上月末的日期:select last_day(add_months(sysdate, -1) from dual; 本月的最后一秒:select trunc(add_months(sysdate
2、,1),MM) - 1/24/60/60 from dual 本周星期一的日期:select trunc(sysdate,day)+1 from dual 年初至今的天数:select ceil(sysdate - trunc(sysdate, year) from dual; 今天是今年的第几周 :select to_char(sysdate,fmww) from dual 今天是本月的第几周:SELECT TO_CHAR(SYSDATE,WW) - TO_CHAR(TRUNC(SYSDATE,MM),WW) + 1 AS weekOfMon FROM dual 本月的天数SELECT to
3、_char(last_day(SYSDATE),dd) days FROM dual 今年的天数select add_months(trunc(sysdate,year), 12) - trunc(sysdate,year) from dual 下个星期一的日期SELECT Next_day(SYSDATE,monday) FROM dual - 计算工作日方法create table t(s date,e date); alter session set nls_date_format = yyyy-mm-dd; insert into t values(2003-03-01,2003-03
4、-03); insert into t values(2003-03-02,2003-03-03); insert into t values(2003-03-07,2003-03-08); insert into t values(2003-03-07,2003-03-09); insert into t values(2003-03-05,2003-03-07); insert into t values(2003-02-01,2003-03-31); - 这里假定日期都是不带时间的,否则在所有日期前加trunc即可。select s,e,e-s+1 total_days, trunc(e
5、-s+1)/7)*5 + length(replace(substr(01111100111110,to_char(s,d),mod(e-s+1,7名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 16 页 - - - - - - - - - ),0,) work_days from t; - drop table t; 引此:http:/ = 判断当前时间是上午下午还是晚上SELECT CASE WHEN to_number(to_char(SYSDATE,hh24) B
6、ETWEEN 6 AND 11 THEN 上午 WHEN to_number(to_char(SYSDATE,hh24) BETWEEN 11 AND 17 THEN 下午 WHEN to_number(to_char(SYSDATE,hh24) BETWEEN 17 AND 21 THEN 晚上 END FROM dual; = Oracle 中的一些处理日期将数字转换为任意时间格式. 如秒 : 需要转换为天/ 小时SELECT to_char(floor(TRUNC(936000/(60*60)/24)|天|to_char(mod(TRUNC(936000/(60*60),24)|小时 F
7、ROM DUAL 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 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 16 页 - - - -
8、 - - - - - 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(
9、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,
10、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格式的类
11、型就是: 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,当然还有很多,可查看名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - -
12、 - - 名师精心整理 - - - - - - - 第 3 页,共 16 页 - - - - - - - - - select * from nls_session_parameters select * from V$NLS_PARAMETERS 8. select count(*) from ( select rownum-1 rnum from all_objects where rownum select sysdate ,to_char(sysdate,hh) from dual; SYSDATE TO_CHAR(SYSDATE,HH) - - 2003-10-13 19:35:21
13、 07 SQL select sysdate ,to_char(sysdate,hh24) from dual; 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 16 页 - - - - - - - - - SYSDATE TO_CHAR(SYSDATE,HH24) - - 2003-10-13 19:35:21 19 获取年月日与此类似13. 年月日的处理select older_date, newer_date, years, months, abs( trunc(
14、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_da
15、te from emp ) ) 14. 处理月份天数不定的办法select to_char(add_months(last_day(sysdate) +1, -2), yyyymmdd),last_day(sysdate) from dual 16. 找出今年的天数select add_months(trunc(sysdate,year), 12) - trunc(sysdate,year) from dual 闰年的处理方法to_char( last_day( to_date(02 & & :year,mmyyyy) ), dd ) 如果是 28 就不是闰年17. yyyy与 rrrr的区别
16、YYYY99 TO_C - - yyyy 99 0099 rrrr 99 1999 yyyy 01 0001 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 5 页,共 16 页 - - - - - - - - - rrrr 01 2001 18. 不同时区的处理select to_char( NEW_TIME( sysdate, GMT,EST), dd/mm/yyyy hh:mi:ss) ,sysdate from dual; 19. 5 秒钟一个间隔Select TO_DATE
17、(FLOOR(TO_CHAR(sysdate,SSSSS)/300) * 300,SSSSS) ,TO_CHAR(sysdate,SSSSS) from dual 2002-11-1 9:55:00 35786 SSSSS 表示 5 位秒数20. 一年的第几天select TO_CHAR(SYSDATE,DDD),sysdate from dual 310 2002-11-6 10:03:51 21. 计算小时 , 分, 秒, 毫秒select Days, A, TRUNC(A*24) Hours, TRUNC(A*24*60 - 60*TRUNC(A*24) Minutes, TRUNC(A
18、*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,
19、365) /30) 作为月mod(mod(date2-date1, 365), 30)作为日 . 23.next_day函数next_day(sysdate,6)是从当前开始下一个星期五。后面的数字是从星期日开始算起。1 2 3 4 5 6 7 日 一 二 三 四 五 六- select (sysdate-to_date(2003-12-03 12:55:45,yyyy-mm-dd 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 6 页,共 16 页 - - - - - - - -
20、- hh24:mi:ss)*24*60*60 from dual 日期返回的是天然后 转换为 ss 转此:http:/ 将数字转换为任意时间格式. 如秒 : 需要转换为天/ 小时SELECT to_char(floor(TRUNC(936000/(60*60)/24)|天|to_char(mod(TRUNC(936000/(60*60),24)|小时 FROM DUAL TO_DATE 格式Day: dd number 12 dy abbreviated fri day spelled out friday ddspth spelled out, ordinal twelfth Month:
21、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_c
22、har(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. 两个日期间的天数名师资料总结 - - -精品资料欢
23、迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 7 页,共 16 页 - - - - - - - - - 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,yyy
24、ymmdd) 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中写s
25、elect 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 select sysdate ,to_char(sysda
26、te,hh) from dual; SYSDATE TO_CHAR(SYSDATE,HH) - - 2003-10-13 19:35:21 07 SQL 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
27、*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 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 9 页,共 16 页 - - - - - - - - - from ( se
28、lect 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 16. 找出今年的天数select add_months(trunc(sysdate,year), 12) - trunc(sysdate,year) from dual 闰年的处理方法to_char( last_da
29、y( to_date(02 & & :year,mmyyyy) ), dd ) 如果是 28 就不是闰年17. yyyy与 rrrr的区别YYYY99 TO_C - - yyyy 99 0099 rrrr 99 1999 yyyy 01 0001 rrrr 01 2001 18. 不同时区的处理select to_char( NEW_TIME( sysdate, GMT,EST), dd/mm/yyyy hh:mi:ss) ,sysdate from dual; 19. 5 秒钟一个间隔Select TO_DATE(FLOOR(TO_CHAR(sysdate,SSSSS)/300) * 300
30、,SSSSS) ,TO_CHAR(sysdate,SSSSS) from dual 2002-11-1 9:55:00 35786 SSSSS 表示 5 位秒数20. 一年的第几天select TO_CHAR(SYSDATE,DDD),sysdate from dual 310 2002-11-6 10:03:51 21. 计算小时 , 分, 秒, 毫秒select Days, A, TRUNC(A*24) Hours, TRUNC(A*24*60 - 60*TRUNC(A*24) Minutes, 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - -
31、- - - - - 名师精心整理 - - - - - - - 第 10 页,共 16 页 - - - - - - - - - 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(r
32、q,yyyymmddhh24miss); / floor(date2-date1) /365) 作为年floor(date2-date1, 365) /30) 作为月mod(mod(date2-date1, 365), 30)作为日 . 23.next_day函数next_day(sysdate,6)是从当前开始下一个星期五。后面的数字是从星期日开始算起。1 2 3 4 5 6 7 日 一 二 三 四 五 六- select (sysdate-to_date(2003-12-03 12:55:45,yyyy-mm-dd hh24:mi:ss)*24*60*60 from dual 日期返回的是
33、天然后 转换为 ss 转此:http:/ 将数字转换为任意时间格式. 如秒 : 需要转换为天/ 小时SELECT to_char(floor(TRUNC(936000/(60*60)/24)|天|to_char(mod(TRUNC(936000/(60*60),24)|小时 FROM DUAL 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
34、spelled out march Year: yy two digits 98 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 11 页,共 16 页 - - - - - - - - - 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_dat
35、e(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,
36、 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)
37、那么 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-
38、mm-dd),day,NLS_DATE_LANGUAGE = American) from dual; 注意我这只是举了NLS_DATE_LANGUAGE,当然还有很多,可查看名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 12 页,共 16 页 - - - - - - - - - select * from nls_session_parameters select * from V$NLS_PARAMETERS 8. select count(*) from ( select r
39、ownum-1 rnum from all_objects where rownum select sysdate ,to_char(sysdate,hh) from dual; SYSDATE TO_CHAR(SYSDATE,HH) - - 2003-10-13 19:35:21 07 SQL select sysdate ,to_char(sysdate,hh24) from dual; 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 13 页,共 16 页 - - - - -
40、- - - - 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 ) ) ) days from ( select trunc(months_between( newer_date, older_date )/12) YEARS, mod(trunc(months_between
41、( 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 16. 找出今年的天数select add_months(trunc(s
42、ysdate,year), 12) - trunc(sysdate,year) from dual 闰年的处理方法to_char( last_day( to_date(02 & & :year,mmyyyy) ), dd ) 如果是 28 就不是闰年17. yyyy与 rrrr的区别YYYY99 TO_C - - yyyy 99 0099 rrrr 99 1999 yyyy 01 0001 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 14 页,共 16 页 - - - - - -
43、 - - - rrrr 01 2001 18. 不同时区的处理select to_char( NEW_TIME( sysdate, GMT,EST), dd/mm/yyyy hh:mi:ss) ,sysdate from dual; 19. 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 位秒数20. 一年的第几天select TO_CHAR(SYSDATE,DDD)
44、,sysdate from dual 310 2002-11-6 10:03:51 21. 计算小时 , 分, 秒, 毫秒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 fr
45、om 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)作为日 . 23.next_day函数next_day(sysdate,6)是从当前开始下一个星期五。后面的数字是从星期日开始算起。1 2 3 4 5 6 7 日 一 二 三 四 五 六- select (sysdate-to_
46、date(2003-12-03 12:55:45,yyyy-mm-dd 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 15 页,共 16 页 - - - - - - - - - hh24:mi:ss)*24*60*60 from dual 日期返回的是天然后 转换为 ss 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 16 页,共 16 页 - - - - - - - - -