Oracle时间操作大全
oracle中tohour()用法
Oracle中to_hour()用法一、概述在O ra cl e数据库中,t o_ho ur()函数是一个非常有用的日期和时间函数。
它可以将给定的日期时间值转换为小时部分,并返回一个数值类型的结果。
本文将详细介绍to_h ou r()函数的用法及示例。
二、语法t o_h ou r()函数的语法如下:T O_H OU R(da te)其中,`da te`参数是一个日期或时间值,可以是日期型、时间型、时间戳型或带有时区的时间戳型。
三、示例说明1.将日期型转换为小时部分假设有一个员工表`e m pl oy ee`,其中包含了员工的入职时间。
我们想要获取所有员工的入职小时数。
可以使用t o_ho ur()函数来实现:S E LE CT TO_H OU R(hir e_d at e)AS hi re_ho u rF R OM em pl oy ee;以上示例中,`h ir e_d at e`是`em pl oy ee`表中的日期型字段,使用t o_h ou r()函数将其转换为小时部分,并将结果命名为`h ir e_h ou r`。
2.将时间型转换为小时部分如果想要将时间型字段转换为小时部分,可以按照以下方式使用t o_h ou r()函数:S E LE CT TO_H OU R(sta r t_ti me)A Ss ta rt_h ou rF R OM sc he du le;以上示例中,`s ta rt_ti me`是`s ch ed ul e`表中的时间型字段,使用t o_h ou r()函数将其转换为小时部分,并将结果命名为`s ta rt_ho ur`。
3.将时间戳型转换为小时部分当需要将时间戳型字段转换为小时部分时,可以使用t o_ho ur()函数的以下语法:S E LE CT TO_H OU R(tim e st am p_co lu mn)AS h ou r_pa rtF R OM ta bl e_na me;以上示例中,`t im es t am p_co lu mn`是表`ta bl e_na me`中的时间戳型字段,使用t o_ho ur()函数将其转换为小时部分,并将结果命名为`h ou r_pa rt`。
oracle年月日时分秒的格式
Oracle年月日时分秒的格式一、概述在数据库系统中,日期和时间的处理是非常重要的一个方面。
Oracle数据库提供了丰富的日期和时间函数,可以满足不同的需求。
其中,日期和时间的格式化是其中的关键操作之一。
在Oracle中,我们可以使用不同的格式来表示年月日时分秒。
本文将详细介绍Oracle中年月日时分秒的格式化方法。
二、日期和时间的数据类型在Oracle数据库中,日期和时间被定义为特殊的数据类型。
主要的数据类型有DATE、TIMESTAMP和TIMESTAMP WITH TIME ZONE等。
这些数据类型可以存储年月日时分秒的信息。
2.1 DATE数据类型DATE数据类型是Oracle中最常用的日期和时间数据类型。
它可以存储从公元前4712年到公元9999年的日期和时间。
DATE数据类型的格式默认为”YYYY-MM-DD HH24:MI:SS”,其中YYYY表示年份,MM表示月份,DD表示日期,HH24表示小时(24小时制),MI表示分钟,SS表示秒钟。
2.2 TIMESTAMP数据类型TIMESTAMP数据类型是Oracle中用于存储日期和时间信息的另一种数据类型。
它可以存储更精确的时间信息,包括毫秒级别的精度。
TIMESTAMP数据类型的格式也是”YYYY-MM-DD HH24:MI:SS.FF”,其中FF表示毫秒。
2.3 TIMESTAMP WITH TIME ZONE数据类型TIMESTAMP WITH TIME ZONE数据类型是一种带有时区信息的日期和时间数据类型。
它可以存储时区偏移量,以便在不同的时区中正确地显示日期和时间。
TIMESTAMP WITH TIME ZONE数据类型的格式与TIMESTAMP数据类型相同。
三、日期和时间的格式化在Oracle数据库中,可以使用不同的函数来格式化日期和时间。
常用的函数有TO_CHAR、TO_DATE和TO_TIMESTAMP等。
3.1 TO_CHAR函数TO_CHAR函数用于将日期和时间数据类型转换为指定的字符串格式。
Oracle中日期时间的操作比较和加减
Oracle中日期时间的操作比较和加减Oracle关于时间/日期的操作日期时间间隔操作当前时间减去分钟的时间select sysdate sysdate interval MINUTE from dual当前时间减去小时的时间select sysdate interval hour from dual当前时间减去天的时间select sysdate interval day from dual当前时间减去月的时间select sysdate sysdate interval month from dual当前时间减去年的时间select sysdate sysdate interval year from dual时间间隔乘以一个数字select sysdate sysdate *interval hour from dual日期到字符操作select sysdate to_char(sysdate yyyy mm dd hh :mi:ss ) from dualselect sysdate to_char(sysdate yyyy mm dd hh:mi:ss ) from dualselect sysdate to_char(sysdate yyyy ddd hh:mi:ss ) from dual select sysdate to_char(sysdate yyyy mm iw d hh:mi:ss ) from dual参考oracle的相关关文档(ORACLE DOC/SERVER /A /SQL_ELEMENTS HTM# )字符到日期操作select to_date( : : yyyy mm dd hh :mi:ss ) from dual具体用法和上面的to_char差不多trunk/ ROUND函数的使用select trunc(sysdate YEAR ) from dualselect trunc(sysdate ) from dualselect to_char(trunc(sysdate YYYY ) YYYY ) from dualoracle有毫秒级的数据类型返回当前时间年月日小时分秒毫秒select to_char(current_timestamp( ) DD MON YYYY HH :MI:SSxFF ) from dual;返回当前时间的秒毫秒可以指定秒后面的精度(最大= )select to_char(current_timestamp( ) MI:SSxFF ) from dual;计算程序运行的时间(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 inloopopen l_rc forselect object_name from all_objects ||where object_id = || i;lishixinzhi/Article/program/Oracle/201311/17649。
oracle时间相减函数
oracle时间相减函数Oracle是一个广泛使用的关系型数据库管理系统,它提供了许多强大的函数和操作符来处理日期和时间数据类型。
其中,时间相减函数是一种常用的功能,它可以用于计算两个时间之间的时间间隔。
在Oracle中,时间相减函数主要包括以下几种:DATEDIFF、TIMESTAMPDIFF、INTERVAL和EXTRACT。
下面将逐一介绍它们的用法和功能。
1. DATEDIFF函数DATEDIFF函数用于计算两个日期之间的天数、小时数、分钟数等时间间隔。
其基本语法如下:DATEDIFF(interval, start_date, end_date)其中,interval参数指定要计算的时间间隔单位,可以是YEAR、MONTH、DAY、HOUR、MINUTE等。
start_date和end_date参数分别指定两个日期。
例如,要计算两个日期之间的天数间隔,可以使用以下语句:SELECT DATEDIFF('DAY', '2022-01-01', '2022-01-10') AS days_diff FROM dual;上述语句将返回结果为9,表示2022年1月1日和2022年1月10日之间相差9天。
2. TIMESTAMPDIFF函数TIMESTAMPDIFF函数用于计算两个时间戳之间的时间间隔。
其基本语法如下:TIMESTAMPDIFF(interval, start_timestamp, end_timestamp)其中,interval参数指定要计算的时间间隔单位,可以是YEAR、MONTH、DAY、HOUR、MINUTE等。
start_timestamp和end_timestamp参数分别指定两个时间戳。
例如,要计算两个时间戳之间的小时数间隔,可以使用以下语句:SELECT TIMESTAMPDIFF('HOUR', '2022-01-01 12:00:00', '2022-01-01 18:00:00') AS hours_diff FROM dual;上述语句将返回结果为6,表示2022年1月1日12:00:00和2022年1月1日18:00:00之间相差6小时。
oracle定时任务时间写法
在Oracle 数据库中,可以使用DBMS_SCHEDULER 包来创建和管理定时任务。
定时任务的时间写法遵循标准的cron 表达式语。
cron 表达式由个或六个字段组成,分表示分钟、小时日期、月份和星期几。
以下是cron 表达式的常见写法:
1. 每分钟执行次:`* * * * *`
2. 每小时的第30 分钟执行一次:`30 * * * *`
3. 每天的8 点执行一次`0 8 * * *`
4. 每周一的9 点执行一次:`0 9 * * 1`
5. 每的第一天12 点执行一次:`0 12 1 * *`
6. 每年的1 月1 日的00:00 执行一次:`0 0 1 1 *`
其中,`*` 表示匹配任意值,例如`* * * * *` 表示每分钟都执行;数字表示具体的数值例如`30 * * * *` 表示每小时的第30 分钟执行;多个数值可以用逗号分隔,例如`1,15,30 * * * *` 表示每小时的第1、15 和30 分钟执行。
此外,还可以使用特字符来表示一些特定的时间段例如:
- `/` 表示步,例如`*/5 * * * *` 表示每隔5 分钟执行一次。
- `-` 表示范围,例如`0 9-17 * * *` 表示每天9 点到17 点之每小时执行一。
以上是一些常见的定时任务时间写法,你可以根据具体求来编写适合的cro n 表式。
oracle date函数使用方法
oracle date函数使用方法Oracle数据库中的日期函数用于处理和操作日期和时间数据。
以下是一些常用的Oracle日期函数及其使用方法:1. `SYSDATE`:返回当前系统日期和时间。
```sqlSELECT SYSDATE FROM dual;```2. `TO_DATE`:将字符串转换为日期格式。
```sqlSELECT TO_DATE('', 'YYYY-MM-DD') FROM dual;```3. `ADD_MONTHS`:在给定日期上添加指定的月份数。
```sqlSELECT ADD_MONTHS(TO_DATE('', 'YYYY-MM-DD'), 3) FROM dual; ```4. `MONTHS_BETWEEN`:返回两个日期之间的月份数。
```sqlSELECT MONTHS_BETWEEN(TO_DATE('', 'YYYY-MM-DD'), TO_DATE('', 'YYYY-MM-DD')) FROM dual;```5. `NEXT_DAY`:返回给定日期后的下一个指定工作日。
```sqlSELECT NEXT_DAY(TO_DATE('', 'YYYY-MM-DD'), 'MONDAY') FROM dual;```6. `LAST_DAY`:返回给定日期的月份的最后一天。
```sqlSELECT LAST_DAY(TO_DATE('', 'YYYY-MM-DD')) FROM dual;```7. `ROUND`:将日期舍入到指定的精度。
```sqlSELECT ROUND(TO_DATE(' 14:30:45', 'YYYY-MM-DD HH24:MI:SS'), 'MONTH') FROM dual;```8. `TRUNC`:将日期截断到指定的精度。
oracle时间函数(求每月第一天,最后一天等)
一、Oracle的日期函数:Oracle从8i开始就提供了大量的日期函数,这些日期函数包括对日期进行加减、转换、截取等功能。
下面是Oracle提供的日期函数一览表 FunctionUseADD_MONTHSAdds months to a dateLAST_DAYComputes the last day of the monthMONTHS_BETWEENDetermines the number of months between two datesNEW_TIMETranslates a time to a new time zoneNEXT_DAYReturns the date of the next specified weekdayROUNDRounds a date/time value to a specified elementSYSDATEReturns the current date and timeTO_CHARConverts dates to stringsTO_DATEConverts strings and numbers to datesTRUNCTruncates a date/time value to a specific element二、日期加减:在Oralce中,对日期进行加减操作的默认单位是天,也就是说如果我们向当前日期加1的话是加上一天,而不是一秒或一小时。
那么对一天中的一段时间进行加减要怎么做呢?很简单!只需将它们转化为以天为单位即可。
【1】为当前时间加上30分钟: SQL> select to_char(sysdate, 'yyyy-mm-dd hh:mi:ss') now_date, to_char(sysdate+(30/24/60), 'yyyy-mm-dd hh:mi:ss') new_date from dual;NOW_DATE NEW_DATE-------------------------------------- -------------------------------------- 2008-06-30 10:47:31 2008-06-30 11:17:31SQL>我们看到了在绿色高亮处使用30/24/60将分钟转换成天。
oracle日期处理全集__日期加减全活儿
1、add_months(d,n) 日期d加n个月SQL> SELECT SYSDA TE AS This_Day,add_months(SYSDATE,1) AS Next_Day FROM dual; THIS_DAY NEXT_DAY-------------- ------------08-9月-10 08-10月-102、last_day(d) 包含d的月份的最后一天的日期SQL> select last_day(sysdate) as last_day from dual;LAST_DAY-----------30-9月-103、new_time(d,a,b) 时区的日期和时间d在b时区的日期和时间SQL> select to_char(sysdate,'YYYY-MM-DD HH24:MI:SS') as china,to_char(new_time(sysdate,'est','GMT'),'YYYY-MM-DD HH24:MI:SS') as GMTfrom dual;CHINA GMT------------------- -------------------2010-09-08 09:51:50 2010-09-08 14:51:504、next_day(d,day) 比日期d晚,由day指定的周几的日期SQL> select sysdate as this_day, next_day(sysdate,7) as next_sat from dual;THIS_DAY NEXT_SAT-------------- --------------08-9月-10 11-9月-10N天前的日期:SQL> select to_date(to_char(sysdate-5, 'yyyy-MM-dd'), 'yyyy-MM-dd') from dual;5、sysdate 当前的系统日期和时间6、greatest(d1,d2,...dn) 给出的日期列表中最后的日期SQL> select sysdate as this_day,greatest(sysdate,sysdate+1,sysdate+2) as max_day from dual; THIS_DAY MAX_DAY-------------- --------------08-9月-10 10-9月-107、least(d1,k2,...dn) 给出的日期列表中最早的日期SQL> select sysdate as this_day,least(sysdate,sysdate+1,sysdate-1) as min_day from dual; THIS_DAY MIN_DAY-------------- --------------08-9月-10 07-9月-108、to_char(d [,fmt]) 日期d按fmt指定的格式转变成字符串SQL> select to_char(sysdate,'YYYY-MM-DD HH24:MI:SS') as today from dual;TODAY-------------------2010-09-08 10:37:089、to_date(st [,fmt]) 字符串st按fmt指定的格式转成日期值,若fmt忽略,st要用缺省格式SQL> select to_date('2010-09-08 10:37:08','YYYY-MM-DD HH24:MI:SS') as today from dual; TODAY--------------08-9月-1010、round(d [,fmt]) 日期d按fmt指定格式舍入到最近的日期SQL> select to_char(sysdate,'YYYY-MM-DD HH24:MI:SS') as this,round(sysdate) as round_day,to_char(sysdate+1/6,'YYYY-MM-DD HH24:MI:SS') as next_4hour,round(sysdate+1/6) as round_dayfrom dual;THIS ROUND_DAY NEXT_4HOUR ROUND_DAY------------------- -------------- ------------------- --------------2010-09-08 10:52:45 08-9月-10 2010-09-08 14:52:45 09-9月-1011、trunc(d [,fmt]) 日期d按fmt指定格式截断到最近的日期SQL> select to_char(sysdate,'YYYY-MM-DD HH24:MI:SS') as this,trunc(sysdate) as trunc_day,to_char(sysdate+1/6,'YYYY-MM-DD HH24:MI:SS') as next_4hour,trunc(sysdate+1/6) as trunc_dayfrom dual;THIS TRUNC_DAY NEXT_4HOUR TRUNC_DAY------------------- -------------- ------------------- --------------2010-09-08 10:56:18 08-9月-10 2010-09-08 14:56:18 08-9月-10to_date 字符串类型转为换日期类型字符串中的相应位置上的字符,必须符合时间范围的限制查询Oracle日期格式----------------------------------select * from nls_database_parameters;得到结果如下表: 表中NLS_DATE_FORMAT表示日期格式.PARAMETER V ALUE----------------------------------- -----------------------------------NLS_LANGUAGE AMERICANNLS_TERRITORY AMERICANLS_CURRENCY $NLS_ISO_CURRENCY AMERICANLS_NUMERIC_CHARACTERS .,NLS_CHARACTERSET ZHS16GBKNLS_CALENDAR GREGORIANNLS_DA TE_FORMAT DD-MON-RRNLS_DA TE_LANGUAGE AMERICANNLS_SORT BINARYNLS_TIME_FORMAT HH.MI.SSXFF AMNLS_TIMESTAMP_FORMAT DD-MON-RR HH.MI.SSXFF AMNLS_TIME_TZ_FORMAT HH.MI.SSXFF AM TZH:TZMNLS_TIMESTAMP_TZ_FORMAT DD-MON-RR HH.MI.SSXFF AM TZH:TZM NLS_DUAL_CURRENCY $NLS_COMP BINARYNLS_NCHAR_CHARACTERSET ZHS16GBKNLS_RDBMS_VERSION 8.1.7.0.0或者查询V$NLS_PARAMETERS表,select * from V$NLS_PARAMETERS;也有类似结果SQL>select to_date('2004-11-12 12-07-32','yyyy-mm-dd hh24-mi-ss') value from dual; V ALUE-------------------2004.11.12 12:07:32SQL>select to_date('20041015') value from dual;V ALUE-------------------2004.10.15 00:00:00SQL>select to_date('20041315') value from dual;ERROR 位于第1 行:ORA-01861: 文字与格式字符串不匹配sysdate 当前日期和时间SQL>select sysdate value from dual;V ALUE-------------------2003.11.23 17:09:01last_day 本月最后一天SQL>select last_day(sysdate) value from dual;V ALUE-------------------2003.11.30 17:08:17add_months(d,n) 日期d后推n个月SQL>select add_months(sysdate,2) value from dual;V ALUE-------------------2005.01.23 17:10:21next_day(d,day) 日期d之后的第一周中,指定的那天(指定星期的第几天)是什么日期SQL>select next_day(sysdate,1) value from dual;V ALUE-------------------2004.11.28 17:38:55[oracle/plsql]oracle日期处理完全版日期处理完全版TO_DA TE格式Day:dd number 12dy abbreviated friday spelled out fridayddspth spelled out, ordinal twelfthMonth:mm number 03mon abbreviated marmonth spelled out marchYear:yy two digits 98yyyy four digits 199824小时格式下时间范围为: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-Two3.求某天是星期几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') fromdual;monday设置日期语言ALTER SESSION SET NLS_DATE_LANGUAGE='AMERICAN';也可以这样TO_DA TE ('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 table1UNIONselect 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点之前是不包含在这个范围之内的。
oracle时间相减函数
oracle时间相减函数Oracle是一种广泛使用的关系型数据库管理系统,它提供了强大的功能和丰富的特性来处理和操作数据。
在Oracle中,时间相减是一个常见的操作,用于计算两个日期之间的时间间隔。
本文将介绍Oracle中常用的时间相减函数,并讨论如何正确使用这些函数来实现时间相减的操作。
在Oracle中,常用的时间相减函数包括DATEDIFF、TIMEDIFF、INTERVAL等。
这些函数允许我们以不同的时间单位计算两个日期之间的差值,如年、月、日、小时、分钟和秒等。
下面我们将详细介绍这些函数的用法和示例。
我们来看一下DATEDIFF函数。
这个函数用于计算两个日期之间的天数差。
它的语法如下所示:```DATEDIFF(date1, date2)```其中,date1和date2是要进行计算的两个日期。
这两个日期可以是直接指定的日期值,也可以是从数据库中检索出来的日期字段。
函数的返回值是两个日期之间的天数差。
接下来,我们来看一个示例。
假设我们有一个订单表,其中包含了订单的创建时间和支付时间。
我们想计算每个订单的支付时间与创建时间之间的天数差。
可以使用以下SQL语句来实现:```SELECT DATEDIFF(pay_time, create_time) AS day_diffFROM orders```在上面的示例中,我们使用DATEDIFF函数来计算支付时间和创建时间之间的天数差,并将结果命名为day_diff。
这样,我们可以得到每个订单的支付时间与创建时间之间的天数差。
除了DATEDIFF函数,Oracle还提供了其他一些时间相减函数。
例如,TIMEDIFF函数可以用来计算两个时间之间的差值,而不考虑日期。
它的语法类似于DATEDIFF函数,只是返回的结果是时间差,而不是天数差。
另外,INTERVAL函数可以用来计算两个日期之间的差值,并将结果以指定的时间单位返回。
这些函数可以根据实际需要选择使用。
oracle比较时间大小的语法
oracle比较时间大小的语法
在Oracle中,要比较时间大小,可以使用比较运算符(如大于号、小于号等)或者内置的日期比较函数。
以下是一些常用的比较时间大小的语法:
1. 使用比较运算符:
大于: `date_column1 > date_column2`。
小于: `date_column1 < date_column2`。
大于等于: `date_column1 >= date_column2`。
小于等于: `date_column1 <= date_column2`。
2. 使用日期比较函数:
比较两个日期的大小: `GREATEST(date1, date2)` 返回较大的日期,`LEAST(date1, date2)` 返回较小的日期。
比较日期是否在某个范围内: 可以使用 `BETWEEN` 关键字进行范围比较,例如 `date_column BETWEEN date1 AND date2`。
3. 使用日期函数进行比较:
除了比较运算符和日期比较函数外,Oracle还提供了一系列日期函数,如 `MONTHS_BETWEEN`、`ADD_MONTHS` 等,可以用来进行日期的加减和比较操作。
需要注意的是,在进行日期比较时,要确保比较的两个日期数据类型一致,可以使用 `TO_DATE` 函数将字符串转换为日期类型,以便进行比较。
总之,在Oracle中比较时间大小的语法可以通过比较运算符、日期比较函数和日期函数来实现,具体使用哪种方式取决于具体的需求和场景。
希望这些信息能够帮助到你。
oracle时间条件写法
在Oracle数据库中,我们可以用各种不同的 ways 时间条件可以以与日期时间相关的查询。
通常,我们会使用 `TO_DATE` 或者`TO_TIMESTAMP` 函数将字符串转化为日期或时间戳,然后再在 WHERE 子句中使用。
以下是一些示例:1. 在特定日期范围内查询记录:SELECT * FROM your_table_nameWHERE date_column >= TO_DATE('2022-01-01', 'YYYY-MM-DD')AND date_column <= TO_DATE('2022-12-31', 'YYYY-MM-DD');1. 查询昨天的记录:SELECT * FROM your_table_nameWHERE TRUNC(date_column) = TRUNC(SYSDATE - 1);1. 查询最近一个小时内的记录:SELECT * FROM your_table_nameWHERE date_column >= (SYSTIMESTAMP - INTERVAL '1' HOUR);1. 查询特定时间范围内的记录(精确到分钟):SELECT * FROM your_table_nameWHERE timestamp_column BETWEEN TO_TIMESTAMP('2023-01-01 15:00:00','YYYY-MM-DD HH24:MI:SS')AND TO_TIMESTAMP('2023-01-01 16:00:00', 'YYYY-MM-DD HH24:MI:SS');这里演示了几个Oracle时间条件的写法。
你可以根据实际需求进行调整。
请注意,上述示例假设你的表格具有 `date_column` 或者 `timestamp_column` 字段,你需要将其替换为实际的列名。
Oracle的日期和时间详解
Oracle的日期和时间详解Oracle 提供了三个用于存储日期/时间值的数据类型:表示日期和时间的DATE 类型。
DA TE 字段中存储的值包含有与世纪、年、月、日、小时、分钟和秒相对应的"组成部分"。
日期可以是公元前4712 年1 月1 日到公元9999 年12 月31 日这一范围中的任何一天。
从Oracle9i开始提供的TIMESTAMP 类型是DA TE 类型的有效扩展格式,并且符合ANSI SQL 标准。
它提供了更大的时间精度,支持多达九位的小数,同时还能够存储时区信息。
从Oracle9i 开始提供的INTERV A类型,它支持存储时间差(如"两年零五个月"或"三天零十八个小时零四十五分钟"),并可以与DATE 或TIMESTAMP进行加法运算以生成一个新的DATE / TIMESTAMP 值。
本文主要介绍DA TE 类型,但适用于DATE 的大部分功能也适用于TIMESTAMP。
(有关TIMESTAMP 和INTERV AL 类型的更多背景知识,请阅读Jonathan Gennick 在Oracle 杂志上发表的文章"Datetime Datatypes Add Precision"和"Finding the Time in Between"(这两篇文章均在2002 年11 月- 12 月刊中发表)。
Oracle 如何存储DATE。
对于Oracle 中的DATE类型,首先要了解的是,它的内部表示形式使它可以通过不同的方法进行显示和操作。
它有效地独立于任何特定的字符串格式。
如果使用SELECT选择一个DATE 类型,Oracle 将自动把它转换为可读字符串,但这并不是值的实际存储方法。
使用SYSDATE 选择当前的系统时间,SYSDATE 返回DA TE 类型的值,是数据库所在的操作系统的当前日期和时间:SELECT SYSDATE FROM dual /* e.g. 25-JUL-05 */该格式受Oracle 参数NLS_DATE_FORMAT 的控制,可以根据每个会话进行更改(如下所示)。
oracle 计算工作日方法
Oracle计算工作日的方法是使用函数`to_char(calendar_date, 'dy')`,这个函数会返回一个字符串,表示指定日期是工作日还是休息日。
其中,如果这一天是工作日,返回值为'Work';如果是休息日,返回值为'Rest'。
但是有时候需要自定义节假日并应用到calendar表中,这时可以按照以下步骤操作:
1. 创建一张表,用来存储自定义的节假日,格式如下:
```sql
CREATE TABLE holiday_table ( id NUMBER, dates DATE );
```
2. 然后,可以使用以下SQL语句,将自定义的节假日更新到calendar表中:
```sql
MERGE INTO calendar cal USING (
SELECT ht.dates, 'N' is_working_day FROM holiday_table ht
) tmp ON (cal.calendar_date = tmp.dates)
WHEN MATCHED THEN UPDATE SET cal.is_working_day = tmp.is_working_day;
```
这样就可以将自定义的节假日应用到calendar表中,从而计算出准确的工作日。
oracle常用的时间格式转换
oracle常⽤的时间格式转换oracle常⽤的时间格式转换1:取得当前⽇期是本⽉的第⼏周select to_char(sysdate,'YYYYMMDD W HH24:MI:SS') from dual;TO_CHAR(SYSDATE,'YY')select to_char(sysdate,'W') from dual;2:取得当前⽇期是⼀个星期中的第⼏天,注意星期⽇是第⼀天select sysdate,to_char(sysdate,'D') from dual; 类似:select to_char(sysdate,'yyyy') from dual; --年select to_char(sysdate,'Q'from dual; --季select to_char(sysdate,'mm') from dual; --⽉select to_char(sysdate,'dd') from dual; --⽇ddd 年中的第⼏天WW 年中的第⼏个星期W 该⽉中第⼏个星期D 周中的星期⼏hh ⼩时(12)hh24 ⼩时(24)Mi 分ss 秒3:取当前⽇期是星期⼏中⽂显⽰:select to_char(sysdate,'day') from dual;TO_CHAR(SYSDATE,'DAY')星期四4:如果⼀个表在⼀个date类型的字段上⾯建⽴了索引,如何使⽤alter session set NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS'5: 得到当前的⽇期select sysdate from dual;6: 得到当天凌晨0点0分0秒的⽇期select trunc(sysdate) from dual;-- 得到这天的最后⼀秒select trunc(sysdate) +0.99999from dual;-- 得到⼩时的具体数值select trunc(sysdate) +1/24from dual;select trunc(sysdate) +7/24from dual;7.得到明天凌晨0点0分0秒的⽇期select trunc(sysdate+1) from dual;select trunc(sysdate)+1from dual;8: 本⽉⼀⽇的⽇期select trunc(sysdate,'mm') from dual;9:得到下⽉⼀⽇的⽇期select trunc(add_months(sysdate,1),'mm') from dual;10:返回当前⽉的最后⼀天?select last_day(sysdate) from dual;select last_day(trunc(sysdate)) from dual;select trunc(last_day(sysdate)) from dual;select trunc(add_months(sysdate,1),'mm') -1from dual;11: 得到⼀年的每⼀天select trunc(sysdate,'yyyy')+ rn -1 date0from(select rownum rn from all_objectswhere rownum<366);12:今天是今年的第N天SELECT TO_CHAR(SYSDATE,'DDD') FROM DUAL;13:如何在给现有的⽇期加上2年select add_months(sysdate,24) from dual;14:判断某⼀⽇⼦所在年分是否为润年select decode(to_char(last_day(trunc(sysdate,'y')+31),'dd'),'29','闰年','平年') from dual;15:判断两年后是否为润年select decode(to_char(last_day(trunc(add_months(sysdate,24),'y')+31),'dd'),'29','闰年','平年') from dual;16:得到⽇期的季度select ceil(to_number(to_char(sysdate,'mm'))/3) from dual;select to_char(sysdate, 'Q') from dual;TO_DATE格式(以时间:2007-11-0213:45:25为例)Year:yy two digits 两位年显⽰值:07yyy three digits 三位年显⽰值:007yyyy four digits 四位年显⽰值:2007Month:mm number两位⽉显⽰值:11mon abbreviated 字符集表⽰显⽰值:11⽉,若是英⽂版,显⽰novmonth spelled out 字符集表⽰显⽰值:11⽉,若是英⽂版,显⽰novemberDay:dd number当⽉第⼏天显⽰值:02ddd number当年第⼏天显⽰值:02dy abbreviated 当周第⼏天简写显⽰值:星期五,若是英⽂版,显⽰friday spelled out 当周第⼏天全写显⽰值:星期五,若是英⽂版,显⽰fridayddspth spelled out, ordinal twelfthHour:hh two digits 12⼩时进制显⽰值:01hh24 two digits 24⼩时进制显⽰值:13Minute:mi two digits 60进制显⽰值:45Second:ss two digits 60进制显⽰值:25其它Q digit 季度显⽰值:4WW digit 当年第⼏周显⽰值:44W digit 当⽉第⼏周显⽰值:124⼩时格式下时间范围为:0:00:00-23:59:59....12⼩时格式下时间范围为:1:00:00-12:59:59 ....1. ⽇期和字符转换函数⽤法(to_date,to_char)select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') as nowTime from dual; //⽇期转化为字符串select to_char(sysdate,'yyyy') as nowYear from dual; //获取时间的年select to_char(sysdate,'mm') as nowMonth from dual; //获取时间的⽉select to_char(sysdate,'dd') as nowDay from dual; //获取时间的⽇select to_char(sysdate,'hh24') as nowHour from dual; //获取时间的时select to_char(sysdate,'mi') as nowMinute from dual; //获取时间的分select to_char(sysdate,'ss') as nowSecond from dual; //获取时间的秒select to_date('2004-05-07 13:23:44','yyyy-mm-dd hh24:mi:ss') from dual//2.select to_char( to_date(222,'J'),'Jsp') from dual显⽰Two Hundred Twenty-Two3.求某天是星期⼏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 table1UNIONselect1, TO_DATE(null) from dual;注意要⽤TO_DATE(null)a_date between to_date('20011201','yyyymmdd') and to_date('20011231','yyyymmdd')那么12⽉31号中午12点之后和12⽉1号的12点之前是不包含在这个范围之内的。
oracle日期计算
oracle日期计算Oracle数据库中提供了很多日期计算的函数和运算符,可以帮助我们完成各种日期计算操作。
下面详细介绍一些常用的日期计算方法。
1.DATE和TIMESTAMP数据类型在Oracle中,DATE数据类型表示日期和时间,精确到秒;而TIMESTAMP数据类型表示日期和时间,精确到纳秒。
我们可以使用这两种数据类型来表示和计算日期。
2.使用SYSDATE函数获取当前日期和时间SYSDATE函数可以获取当前日期和时间。
例如,可以使用SELECTSYSDATEFROMDUAL;语句来查询当前日期和时间。
3.使用TO_DATE函数将字符串转换为日期TO_DATE函数可以将字符串转换为日期。
例如,使用SELECTTO_DATE('2024-01-01','YYYY-MM-DD')FROMDUAL;语句将字符串'2024-01-01'转换为日期。
4.使用ADD_MONTHS函数添加月份ADD_MONTHS函数可以在一个日期上添加指定的月数。
例如,使用SELECTADD_MONTHS(SYSDATE,1)FROMDUAL;语句可以获取当前日期后一个月的日期。
5.使用MONTHS_BETWEEN计算两个日期之间的月份差MONTHS_BETWEEN函数可以计算两个日期之间的月份差。
例如,使用SELECTMONTHS_BETWEEN(TO_DATE('2024-12-01','YYYY-MM-DD'),TO_DATE('2024-01-01','YYYY-MM-DD'))FROMDUAL;语句可以计算出2024年12月1日与2024年1月1日之间的月份差。
6.使用NEXT_DAY函数查找下一个指定的星期日期NEXT_DAY函数可以查找下一个指定的星期日期。
例如,使用SELECTNEXT_DAY(SYSDATE,'FRIDAY')FROMDUAL;语句可以查找下一个星期五的日期。
oracle的时间循环语句
在Oracle 数据库中,通常使用CONNECT BY子句进行递归查询,以实现时间的循环或递增。
以下是一个简单的例子,演示了如何使用CONNECT BY创建一个简单的时间序列:
假设有一个表time_table包含字段time_value,表示时间的值。
我们可以使用如下的SQL 语句生成一个从当前日期开始的未来十天的时间序列:SELECT
SYSDATE + LEVEL - 1 AS time_value
FROM
dual
CONNECT BY
LEVEL <= 10;
上述查询的关键点如下:
- SYSDATE表示当前日期。
- LEVEL是CONNECT BY子句中的一个伪列,表示查询的层级。
- CONNECT BY LEVEL <= 10表示循环执行直到LEVEL 到达10。
这个查询会生成一个包含十行的结果集,每一行包含从当前日期开始的未来十天的日期。
请注意,上述语法是一个简单的例子。
在实际应用中,你可能需要更复杂的条件来满足特定的需求。
此外,如果你在时间序列中包含了大量的数据,递归查询可能会影响性能,因此需要谨慎使用。
在Oracle 数据库中,还可以使用CONNECT BY PRIOR子句来处理更复杂的递归关系。
oracle dateformat用法
一、日期时间数据类型简介在数据库中,日期时间数据类型用于存储日期和时间信息。
Oracle数据库中有三种主要的日期时间数据类型:DATE、TIMESTAMP、和TIMESTAMP WITH TIME ZONE。
每种数据类型都有自己的特点和用途。
二、 Oracle DATE数据类型1. DATE数据类型的用途DATE数据类型被用于存储日期和时间信息。
它包含年、月、日、小时、分钟和秒的信息。
2. DATE数据类型的格式DATE数据类型的默认显示格式为"YYYY-MM-DD HH24:MI:SS",其中YYYY代表年,MM代表月,DD代表日,HH24代表小时(24小时制),MI代表分钟,SS代表秒。
3. DATE数据类型的存储容量DATE数据类型在Oracle数据库中占用7个字节的存储空间。
4. DATE数据类型的使用可以使用TO_CHAR函数将DATE数据类型转换为指定格式的字符串输出,也可以使用TO_DATE函数将字符串转换为DATE数据类型。
三、 Oracle DATE数据类型的格式化1. 日期时间格式化符号Oracle提供了一系列的日期时间格式化符号,用于指定日期时间的显示格式。
常用的格式化符号包括:- YYYY:4位年份- MM:月份(01-12)- DD:日(01-31)- HH24:小时(00-23)- MI:分钟(00-59)- SS:秒(00-59)2. 日期时间格式化示例对DATE数据类型进行格式化输出的示例:- SELECT TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS') FROM DUAL;-- 输出结果类似于"2022-07-21 15:30:45"- SELECT TO_CHAR(SYSDATE, 'YYYY年MM月DD日 HH24时MI 分SS秒') FROM DUAL;-- 输出结果类似于"2022年07月21日 15时30分45秒"四、 Oracle DATE数据类型的默认格式1. NLS_DATE_FORMAT参数Oracle数据库使用NLS_DATE_FORMAT参数来控制DATE数据类型的默认显示格式。
数据库中日期时间用法
转一篇oracle日期时间用法的文章,十分有用!--------------------------------------------------------------相信很多人都有过统计某些数据的经历,比如,要统计财务的情况,可能要按每年,每季度,每月,甚至每个星期来分别统计。
那在oracle中应该怎么来写sql语句呢,这个时候Oracle 的日期函数会给我们很多帮助。
常用日期型函数1。
Sysdate 当前日期和时间SQL> Select sysdate from dual;SYSDATE----------21-6月-052。
Last_day 本月最后一天SQL> Select last_day(sysdate) from dual;LAST_DAY(S----------30-6月-053。
Add_months(d,n) 当前日期d后推n个月用于从一个日期值增加或减少一些月份date_value:=add_months(date_value,number_of_months)SQL> Select add_months(sysdate,2) from dual;ADD_MONTHS----------21-8月-054。
Months_between(f,s) 日期f和s间相差月数SQL> select months_between(sysdate,to_date('2005-11-12','yyyy-mm-dd'))from dual;MONTHS_BETWEEN(SYSDA TE,TO_DA TE('2005-11-12','YYYY-MM-DD'))-----------------------------------------------------------4.69667415。
NEXT_DAY(d, day_of_week)返回由"day_of_week"命名的,在变量"d"指定的日期之后的第一个工作日的日期。
Oracle时间日期操作
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,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_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-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即可。
oracle取某个时间段的数据(每周几的上午几点到几点)
oracle取某个时间段的数据(每周⼏的上午⼏点到⼏点)oracle 取某个时间段的数据,具体代码如下所⽰:select count(*),t.分组字段 from (select t.* ,to_char(t.时间,'HH24') stime,to_char(t.时间,'HH24mi') fz,to_char(时间,'d')from A twhere 时间>=to_date('2019-12-01','yyyy-MM-dd') and ghsj<=to_date('2019-12-31','yyyy-MM-dd') and to_char(时间,'d')='2') where stime in ('08','09','10','11','12') and fz>=0800 agroup by T.分组字段to_char(时间,'d') 取当前时间是星期⼏每星期第⼀天为周⽇to_char(t.时间,'HH24mi') 取当前时间的⼩时分o_char(t.时间,'HH24') 取当前时间的⼩时ps:oracle 同⼀个数据有多条记录,根据条件取时间最⼤的那⼀条1.第⼀种⽅式select max(t1.INVALID_TIME) from T_CUSTOMER t1 where t1.customer_code = '5101'1.第⼆种⽅式SELECT INVALID_TIME FROM (SELECT * FROM T_CUSTOMER WHERE customer_code='5101' ORDER BY INVALID_TIME desc) WHERE ROWNUM =11.第三种⽅式select INVALID_TIME from T_CUSTOMER t where INVALID_TIME=(select max(INVALID_TIME) from T_CUSTOMER where customer_code='5101') and ROWNUM =1 5.不过滤存在多条最⼤时间select INVALID_TIME from T_CUSTOMER t wheret.INVALID_TIME = (select max(t1.INVALID_TIME) from T_CUSTOMER t1 where t1.customer_code = '5101')总结以上所述是⼩编给⼤家介绍的oracle 取某个时间段的数据(每周⼏的上午⼏点到⼏点),希望对⼤家有所帮助!。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
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,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_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-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-s+1)/7)*5 +length(replace(substr('01111100111110',to_char(s,'d'),mod(e-s+1,7)),'0','')) work_daysfrom t;-- drop table t;引此:/showthread.php?s=1635506cd5f48b1bc3adbe4cde96f227&threadid=104060&perpage=15&pagenumber=1===================================================================== ===========判断当前时间是上午下午还是晚上SELECT CASEWHEN to_number(to_char(SYSDATE,'hh24')) BETWEEN 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 '晚上' ENDFROM dual;===================================================================== ===========Oracle 中的一些处理日期将数字转换为任意时间格式.如秒:需要转换为天/小时SELECT to_char(floor(TRUNC(936000/(60*60))/24))||'天'||to_char(mod(TRUNC(936000/(60*60)),24))||'小时' FROM DUALTO_DATE格式Day:dd number 12dy abbreviated friday spelled out fridayddspth spelled out, ordinal twelfthMonth:mm number 03mon abbreviated marmonth spelled out marchYear:yy two digits 98yyyy four digits 199824小时格式下时间范围为: 0:00:00 - 23:59:59....12小时格式下时间范围为: 1:00:00 - 12:59:59 ....日期和字符转换函数用法(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','yyyy-mm-dd'),'day') from dual; 星期一selectto_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 table1UNIONselect 1, TO_DATE(null) from dual;注意要用TO_DATE(null)6.a_date between to_date('20011201','yyyymmdd') andto_date('20011231','yyyymmdd')那么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','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE = American') from dual;注意我这只是举了NLS_DATE_LANGUAGE,当然还有很多,可查看select * from nls_session_parametersselect * from V$NLS_PARAMETERSselect count(*)from ( select rownum-1 rnumfrom all_objectswhere 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' )notin ( '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;1select months_between(to_date('02-01-1999','MM-DD-YYYY'),to_date('12-31-1998','MM-DD-YYYY')) "MONTHS" FROM DUAL;1.0322580645161310. Next_day的用法Next_day(date, day)Monday-Sunday, for format code DAYMon-Sun, for format code DY1-7, for format code D11select to_char(sysdate,'hh:mi:ss') TIME from all_objects注意:第一条记录的TIME 与最后一行是一样的可以建立一个函数来处理这个问题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-16 2:38:40') from offer SQL> 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.处理月份天数不定的办法select to_char(add_months(last_day(sysdate) +1, -2),'yyyymmdd'),last_day(sysdate) from dual16.找出今年的天数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的区别'YYYY99 TO_C------- ----yyyy 99 0099rrrr 99 1999yyyy 01 0001rrrr 01 200118.不同时区的处理select to_char( NEW_TIME( sysdate, 'GMT','EST'), 'dd/mm/yyyyhh:mi:ss') ,sysdatefrom dual;19.5秒钟一个间隔Select TO_DATE(FLOOR(TO_CHAR(sysdate,'SSSSS')/300) *300,'SSSSS') ,TO_CHAR(sysdate,'SSSSS')from dual2002-11-1 9:55:00 35786SSSSS表示5位秒数20.一年的第几天select TO_CHAR(SYSDATE,'DDD'),sysdate from dual310 2002-11-6 10:03:5121.计算小时,分,秒,毫秒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,'yyyymmddhh24miss'); //floor((date2-date1) /365) 作为年floor((date2-date1, 365) /30) 作为月mod(mod(date2-date1, 365), 30)作为日.23.next_day函数next_day(sysdate,6)是从当前开始下一个星期五。