oracle处理日期时间
oracle 中时间用法
oracle 中时间用法在Oracle数据库中,时间的处理和使用是非常重要的。
Oracle提供了许多用于处理时间的函数和数据类型,以下是一些常见的时间用法:1. 数据类型:DATE,Oracle中用于存储日期和时间的数据类型。
它包含年、月、日、时、分和秒的信息。
TIMESTAMP,比DATE类型精确度更高的日期和时间数据类型,可以精确到纳秒级别。
2. 获取当前时间:使用SYSDATE函数可以获取当前的日期和时间。
使用CURRENT_TIMESTAMP函数可以获取当前的时间戳。
3. 日期和时间函数:TO_DATE,将字符串转换为日期类型。
TO_CHAR,将日期类型格式化为字符串。
EXTRACT,从日期中提取特定的部分,比如年、月、日、小时等。
ADD_MONTHS,在日期上加上指定的月数。
MONTHS_BETWEEN,计算两个日期之间相差的月数。
4. 日期和时间运算:可以使用+和-运算符在日期上进行加减操作。
可以对日期进行比较,判断日期的先后顺序。
5. 时区转换:使用AT TIME ZONE可以将日期和时间从一个时区转换到另一个时区。
使用FROM_TZ和CAST函数可以进行时区转换。
6. 时间戳:可以使用TO_TIMESTAMP将字符串转换为时间戳类型。
可以使用FROM_TZ函数将带有时区信息的日期转换为时间戳类型。
7. 时区信息:Oracle数据库中存储了时区信息,可以通过查询相关的数据字典视图来获取时区信息。
总的来说,Oracle提供了丰富的日期和时间处理功能,可以满足各种复杂的时间需求。
通过合理使用日期和时间函数,可以方便地进行日期和时间的计算、转换和格式化。
同时,时区的处理也是Oracle日期和时间处理中需要特别注意的部分,确保在多时区环境下能够正确处理日期和时间数据。
数据库日期格式处理(Oracle)
TO_DATE格式(以时间:2007-11-02 13: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 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数据库中,日期和时间被定义为特殊的数据类型。
主要的数据类型有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 timestamp 格式
oracle timestamp 格式
Oracle Timestamp格式是指Oracle数据库中存储日期和时间的数据类型,表示为特定的格式。
在Oracle中,可以将日期或日期时间存储为不同的数据类型。
其中,Timestamp 数据类型是保存日期和时间指定的精度的最准确的数据类型。
TO_TIMESTAMP('YYYY-MM-DD HH24:MI:SS.FF')
其中,YYYY表示年份,MM表示月份,DD表示日期,HH表示小时,MI表示分钟,SS表示秒数;FF表示小数秒(注意是大写的FF)。
例如:
TO_TIMESTAMP('2021-11-22 13:15:30.123456')
这个时间戳表示2021年11月22日下午1:15:30.123456秒。
这意味着,它的精度比时间格式更高,可以存储小数秒的值。
此外,可以指定时区信息,例如:
在Oracle中,还可以使用一些额外的函数来处理日期和时间戳。
例如:
- SYSDATE: 返回当前系统日期和时间。
- SYSTIMESTAMP: 返回当前系统日期和时间戳。
- ADD_MONTHS: 在日期上添加月数。
- MONTHS_BETWEEN: 计算两个日期之间的月份数。
- ROUND: 对日期或时间进行四舍五入操作。
在Oracle数据库中,使用不同的日期或时间数据类型需要注意数据类型的格式和使用范围。
虽然Oracle Timestamp是一种广泛使用的日期和时间数据类型,但在数据库设计和实现方面需要自行根据业务需要决定选择哪种数据类型。
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中trunc()函数用法处理日期、数字类型数据
trunc()函数用法处理日期、数字类型数据一、日期TRUNC函数为指定元素而截去的日期值。
其具体的语法格式如下:TRUNC(date[,fmt])其中:date 一个日期值fmt 日期格式,该日期将由指定的元素格式所截去。
忽略它则由最近的日期截去如果当日日期是:2011-3-181.select trunc(sysdate) from dual --2011-3-18 今天的日期为2011-3-182.select trunc(sysdate, 'mm') from dual --2011-3-1 返回当月第一天.3.select trunc(sysdate,'yy') from dual --2011-1-1 返回当年第一天4.select trunc(sysdate,'dd') from dual --2011-3-18 返回当前年月日5.select trunc(sysdate,'yyyy') from dual --2011-1-1 返回当年第一天6.select trunc(sysdate,'d') from dual --2011-3-13 (星期天)返回当前星期的第一天7.select trunc(sysdate, 'hh') from dual --2011-3-18 14:00:00 当前时间为14:418.select trunc(sysdate, 'mi') from dual --2011-3-18 14:41:00 TRUNC()函数没有秒的精确二、数字TRUNC(number,num_digits)Number 需要截尾取整的数字。
Num_digits 用于指定取整精度的数字。
Num_digits 的默认值为0。
TRUNC()函数截取时不进行四舍五入9.select trunc(123.458) from dual --12310.select trunc(123.458,0) from dual --12311.select trunc(123.458,1) from dual --123.412.select trunc(123.458,-1) from dual --12013.select trunc(123.458,-4) from dual --014.select trunc(123.458,4) from dual --123.45815.select trunc(123) from dual --12316.select trunc(123,1) from dual --12317.select trunc(123,-1) from dual --120。
Oracle日期函数和转换函数
Oracle⽇期函数和转换函数⼀、⽇期函数⽇期函数⽤于处理date类型的数据,两个⽇期相减返回⽇期之间相差的天数。
⽇期不允许做加法运算,⽆意义。
常见代表符号:yyyy 年,mm ⽉,dd ⽇,hh ⼩时,mi 分钟,ss 秒,day 星期默认情况下⽇期格式是dd-mon-yy即12-3⽉-19(1)sysdate: 该函数返回系统时间(2)months_between(m,n)⽇期m和⽇期n相差多少⽉数(3)add_months(d,n)在⽇期d上增加n个⽉数(4)next_day(d, '星期*') 指定⽇期d下⼀个星期*对应的⽇期(5)last_day(d):返回指定⽇期d所在⽉份的最后⼀天(6)extract(month from d)从⽇期d上提取⽉份数(7)round(d,time)⽇期的四舍五⼊(8)trunc(d,time)⽇期的截断以下是⽇期函数的⼀些例⼦及效果图:各种情况例⼦:months_between select months_between('01-9⽉-95','11-1⽉-94') from dual; --19.6774193548387add_months select add_months('11-2⽉-18',6) from dual; --2018/8/11next_day select next_day('11-2⽉-18','星期六') from dual; --2018/2/17last_day select last_day('11-2⽉-18') from dual; --2018/2/28round 四舍五⼊⽉份 25-7⽉-18 select round(to_date('25-7⽉-2018'), 'month') from dual; --2018/8/1round 四舍五⼊年份 25-7⽉-18 select round(to_date('25-7⽉-2018’), 'year') from dual; --2019/1/1trunc 截断⽉份 25-7⽉-18 select trunc(to_date('25-7⽉-2018'), 'month') from dual; --2018/7/1trunc 截断年份 25-7⽉-18 select trunc(to_date('25-7⽉-2018'), 'year') from dual; --2018/1/1trunc 当前⽇期的00点00分00秒 select trunc(sysdate) from dual;sql⽐较⽇期今天之前:select * from table where update < to_date('2012-09-07 00:00:00', 'yyyy-MM-dd HH24:mi:ss');精确时间:select * from table where update = to_date('2012-09-07 00:00:00', 'yyyy-MM-dd HH24:mi:ss');某段时间内:select * from table where update <= to_date('2012-09-07 00:00:00', 'yyyy-MM-dd HH24:mi:ss')and update >= to_date('2010-02-07 00:00:00', 'yyyy-MM-dd HH24:mi:ss')eg:查找已经⼊职8个⽉多的员⼯SQL>select * from empwhere sysdate>=add_months(hiredate,8);eg:显⽰满10年服务年限的员⼯的姓名和受雇⽇期。
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的日期和时间详解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⽇期和时间转换1、timestamp与字符串转换timestamp转字符串:select to_char(t.timestamp,'yyyy-mm-dd HH24:mi:ss.ff') from tb_a t字符串转timestamp:update tb_a t set t.timestamp=to_timestamp('2012-12-12 12:12:12.0','yyyy-mm-dd hh24:mi:ss.ff') where t.id='1' 2、date与字符串转换select to_char(sysdate,'yy-mm-dd hh24:mi:ss') from dual //显⽰:08-11-07 13:22:42select to_date('2005-12-25,13:25:59','yyyy-mm-dd hh24:mi:ss') from dual //显⽰:2005-12-25 13:25:593、hh24:mi:ss.ffff后⾯的数字表⽰秒后⾯的⼩数位--查询当前系统⽇期:Oracle: select to_char(sysdate, 'yyyy-mm-dd') from dual;Mysql:select current_date();或者select curdate();--查询当前系统时间:Oracle: select to_char(sysdate, 'hh24:mi:ss') from dual;Mysql: select curtime();或者select current_time();--查询系统⽇期和时间:Oracle: select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;Mysql: select sysdate(); 或者select now();--时间戳:Oracle: select systimestamp from dual;Mysql: select current_timestamp()4、--时间戳类型,参数6指的是表⽰秒的数字的⼩数点右边可以存储6位数字,最多9位。
oracle interval day用法
oracle interval day用法对于Oracle数据库,处理时间和日期数据类型是一个基本操作。
日期和时间间隔是在Oracle SQL中非常常见的数据类型,因此应该了解如何在Oracle SQL中使用这些数据类型。
Oracle提供了一些功能来处理时间和日期,例如INTERVAL DAY TO SECOND、INTERVAL YEAR TO MONTH和EXTRACT。
在Oracle SQL中,INTERVAL DAY TO SECOND是一个数据类型,用于表示两个时间之间的差异。
使用INTERVAL DAY TO SECOND类型,还可以存储时间段,例如一个会议的持续时间或一个任务的执行时间。
使用INTERVAL DAY TO SECOND类型,可以将时间差异以天、小时、分钟和秒的形式表示。
以下是使用INTERVAL DAY TO SECOND数据类型的用法:1.创建INTERVAL DAY TO SECOND类型的列在创建表时,可以将INTERVAL DAY TO SECOND数据类型用作列类型,如下所示:CREATE TABLE meetings (meeting_id NUMBER(10),start_time DATE,end_time DATE,duration INTERVAL DAY TO SECOND);2.插入INTERVAL DAY TO SECOND类型的数据可以使用DATE和TO_DSINTERVAL函数来插入INTERVAL DAY TO SECOND类型的数据,如下所示:INSERT INTO meetings (meeting_id, start_time, end_time, duration)VALUES (1,TO_DATE('2022-08-01 09:00:00', 'YYYY-MM-DDHH24:MI:SS'),TO_DATE('2022-08-01 12:00:00', 'YYYY-MM-DDHH24:MI:SS'),TO_DSINTERVAL('0 03:00:00'));3.计算INTERVAL DAY TO SECOND类型的数据可以使用加减运算符来计算INTERVAL DAY TO SECOND类型的数据,如下所示:SELECT end_time - start_time as total_timeFROM meetings;这将返回一个INTERVAL DAY TO SECOND类型的值,表示会议的总持续时间。
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的日期运算
上月末的日期:select last_day(add_months(sysdate, -1)) from dual;
本月的最后一秒:select trunc(add_months(sysdate,1),'MM') - 1/24/60/60 from dual
注意我这只是举了NLS_DATE_LANGUAGE,当然还有很多,
可查看
select * from nls_session_parameters
select * from V$NLS_PARAMETERS
8.
select count(*)
from ( select rownum-1 rnum
也可以这样
TO_DATE ('2002-08-26', 'YYYY-mm-dd', 'NLS_DATE_LANGUAGE = American')
4.
两个日期间的天数
select floor(sysdate - to_date('20020405','yyyymmdd')) from dual;
SQL> select sysdate ,to_char(sysdate,'hh') from dual;
SYSDATE TO_CHAR(SYSDATE,'HH')
-------------------- ---------------------
2003-10-13 19:35:21 07
not
in ( '1', '7' )
oracle todate,ddd用法
在Oracle数据库中,TO_DATE和DDD(Day of Year)都是用于日期处理的函数和数据类型。
下面我会分别解释它们的用法。
1. TO_DATE函数
TO_DATE函数用于将字符串转换为日期类型。
它需要两个参数:要转换的字符串和该字符串的格式。
语法:
sql复制代码
TO_DATE(string, format)
•string: 要转换的字符串。
•format: 日期字符串的格式。
示例:
sql复制代码
SELECT TO_DATE('2023-10-23', 'YYYY-MM-DD') FROM DUAL;
2. DDD日期格式
在Oracle中,日期可以以多种格式显示,其中DDD是表示年份中的第几天的格式。
通常与TO_CHAR函数一起使用,将日期转换为DDD格式。
语法:
sql复制代码
TO_CHAR(date, 'DDD')
•date: 要转换的日期。
•'DDD': 表示日期的格式。
示例:
sql复制代码
SELECT TO_CHAR(TO_DATE('2023-10-23', 'YYYY-MM-DD'), 'DDD') FROM DUAL;
这个查询将返回字符串235,表示2023年的第235天(从一年的第一天开始计算)。
注意:在使用这些函数时,请确保你的日期字符串和格式字符串的格式是正确的,否则可能会得到不正确的结果或错误。
数据库中日期时间用法
转一篇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 timestamp运算
文章标题:深度解析Oracle中的Timestamp运算在Oracle数据库中,Timestamp类型是一种用来存储日期和时间信息的数据类型。
它可以精确到毫秒级别,非常适合在数据库中处理时间相关的操作。
本文将从多个角度对Oracle中的Timestamp运算进行全面分析,帮助读者更好地理解和应用这一功能。
一、Timestamp类型简介Timestamp是Oracle数据库中的一种日期时间类型,它包含了日期和时间的信息,可以精确到毫秒。
在数据库中,我们可以使用Timestamp类型来存储时间戳、记录时间信息等。
可以使用Timestamp类型来存储订单创建时间、交易发生时间等。
二、Timestamp的基本运算1. Timestamp的加法运算在Oracle数据库中,我们可以对两个Timestamp进行加法运算。
我们可以计算两个时间点之间的时间差,或者在某个时间点上加上一定的时间间隔。
这对于一些需要对时间进行计算的业务场景非常有用。
2. Timestamp的减法运算除了加法运算,我们还可以对Timestamp进行减法运算。
我们可以计算两个时间点之间的时间差,或者计算某个时间点距离当前时间的时间间隔。
这对于一些需要对时间进行比较或计算的业务场景也非常重要。
三、Timestamp运算的高级应用1. Timestamp的比较运算在实际应用中,我们经常需要比较两个时间点的先后顺序。
这时,Timestamp类型的比较运算就非常有用。
通过比较运算,我们可以判断哪个时间点在前,哪个时间点在后,从而进行相应的业务逻辑处理。
2. Timestamp的格式转换有时候,我们需要将Timestamp类型转换成指定的日期时间格式,或者将指定的日期时间格式转换成Timestamp类型。
在Oracle数据库中,有专门的函数可以实现这些格式之间的转换,提供了非常便利的方法。
四、个人观点和理解在实际项目中,我经常使用Oracle中的Timestamp类型进行时间相关的运算和处理。
oracle日期处理全集__日期加减全活儿.doc
1 x add_months(d,n)日期d 加n 个月SQL> SELECT SYSDATE AS This_Day,add_months(SYSDATE, 1) AS Next_Day FROM dual; THIS_DAY NEXT_DAY08・9月-10 08-10月JO2、last_day(d)包含(1的月份的最丿舌一天的日期SQL> select last_day(sysdate) as last_day from dual;LAST.DAY3()・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;est7GMT);YYYY-MM-DD HH24:MI:SS,) as GMT from dual; CHINA GMT2010-09-08 09:51:50 2010-09-08 14:51:504^ next_day(d,day)比日期d晚,rfl day指定的周几的日期SQL> select sysdate as this_day, next_day(sysdate,7) as next_sat from dual;THIS_DAY NEXT_SAT0&9 月-10 11-9月-10N天前的日期:SQL> select to_date(to_char(sysc!ate-5, 'yyyy・MM-dcT), ^yyyy-MM-dd1) from dual;5、sysdate当前的系统日期和时间6^ greatest(dl,d2,...dn)给出的日期列表中最后的日期SQL> select sysdate as this_day,greatest(sysdate,sysdate+1 ,sysdate+2) as max_day from dual; THIS_DAY MAX_DAY0&9 月-10 10・9 月-107、least(dl,k2,...dn)给出的日期列表中最早的日期SQL> select sysdate as this_day,least(sysdate,sysdate+1 .sysdate-1) as min_day from dual;THIS_DAY MIN_DAY08・9月-10 07・9月-108、to_char(d 口期d按fmt指定的格式转变成字符串SQL> select to_char(sysdate,'YYYY-MM-DD HH24:MI:SS') as today from dual;TODAY2010-09-08 10:37:089、to_date(st 字符串st按fmt指定的格式转成日期值,若fmt忽略,st要用缺省格式SQL> select to_date(*2010-09-08 10:37:087YYYY-MM-DD HH24:MI:SS,) as today from dual; TODAY08・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 r) as next_4hour ,round(sysdate+1/6) as round_dayfrom dual;THIS ROUND.DAY NEXT_4HOUR ROUND_DAY2010-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) astrunc_dayfrom dual;THIS TRUNC.DAY NEXT_4HOUR TRUNC.DAY2010-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 VALUENLS_LANGUAGE AMERICANNLS_TERRITORY AMERICANLS.CURRENCY $NLS_ISO_CURRENCY AMERICANLS_NUMERIC_CHARACTERSNLS_CHARACTERSET ZHS16GBKNLS CALENDAR GREGORIANNLS_DATE_FORMAT DD-MON-RRNLS_DATE_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:TZMNLS_DUAL_CURRENCY $P BINARYNLS_NCHAR_CHARACTERSET ZHS16GBKNLS_RDBMS_VERSION 8.1.7.0.0或者查询V$NLS_PARAMETERS 表,select * from V$NLS_PARAMETERS;也有类似结果SQL>select to_date(*2004-l 1-12 12-07-32*,*yyyy-mm-dd hh24-mi-ss*) value from dual;VALUE2004」1.12 12:07:32SQL>select to_date('20041015*) value from dual;VALUE2004」0」5 00:00:00SQL>select to_date('20041315') value from dual;ERROR位于第1行:ORA-01861:文字与格式字符串不匹配sysdate当前日期和时间SQL>select sysdate value from dual;VALUE2003.11.23 17:09:01last_day本月最后一天SQL>select last_day(sysdate) value from dual;VALUE2003.11.30 17:08:17add_months(d,n)日期d后推n个月SQL>select add_months(sysdate,2) value from dual;VALUE2005.01.23 17:10:21 next_day(d,day)日期d Z后的第一周屮,指定的那天(指定星期的第儿天)是什么日期SQL>select next_day(sysdateJ) value from dual;VALUE2004.11.28 17:38:55[oracle/plsql]oracle日期处理完全版日期处理完全版TO.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 ....1.H期和字符转换函数用法(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') from dual;monday设置日期语言ALTER SESSION SET NLS_DATE_LANGUAGE二'AMERICAN';也可以这样TO.DATE C2002-08-26\ 'YYYY・mm・dd;,NLS_DATE_LANGUAGE = American*)4.两个tl期问的天数select floor(sysdate ・ to_date(,20020405','yyyymmdd')) from dual;5.时间为null的用法select id, active_date from table 1UNIONselect 1, TO_DATE(nuil) from dual;注意要用TO_DATE(null)a_date between to_date('20011201 ','yyyymmdd*) and to_date('20011231 '/yyyymmdd')那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
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即可。
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=1040 60&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 ....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') 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') 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 = Americanalter 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_parametersselect * from V$NLS_PARAMETERS8.select count(*)from ( select rownum-1 rnumfrom all_objectswhere rownum <= to_date('2002-02-28','yyyy-mm-dd') - to_date('2002- <br /> 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/yyyy hh: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)是从当前开始下一个星期五。