Oracle 时间类型

1、常用日期型数据类型
1.1、DATE
这是ORACLE最常用的日期类型,它可以保存日期和时间,常用日期处理都可以采用这种类型。DATE表示的日期范围可以是公元前4712年1月1日至公元9999年12月31日
date类型在数据库中的存储固定为7个字节,格式为:
 第1字节:世纪+100
 第2字节:年
 第3字节:月
 第4字节:天
 第5字节:小时+1
 第6字节:分+1
 第7字节:秒+1

1.2、TIMESTAMP(p)
这也是ORACLE常用的日期类型,它与date的区别是不仅可以保存日期和时间,还能保存小数秒,小数位数可以指定为0-9,默认为6位,所以最高精度可以到ns(纳秒),数据库内部用7或者11个字节存储,如果精度为0,则用7字节存储,与date类型功能相同,如果精度大于0则用11字节存储。
格式为:
 第1字节:世纪+100
 第2字节:年
 第3字节:月
 第4字节:天
 第5字节:小时+1
 第6字节:分+1
 第7字节:秒+1
 第8-11字节:纳秒,采用4个字节存储,内部运算类型为整形

注:TIMESTAMP日期类型如果与数值进行加减运算会自动转换为DATE型,也就是说小数秒会自动去除。

1.3、DATE与TIMESTAMP类型内部存储验证

2、常见问题
2.1、如何取当前时间
sysdate--返回当前系统日期和时间,精确到秒
systimestamp--返回当前系统日期和时间,精确到毫秒
2.2、如何进行日期运算
日期型数据可以与数值加减得到新的日期,加减数值单位为天
sysdate+1--取明天的当前时间
sysdate-1/24--取当前时间的前一个小时

select sysdate d1,sysdate+1 d2,sysdate-1/24 d3 from dual;

D1                       D2                       D3
------------------------ ------------------------ ------------------------
2010-5-13 下午 10:55:16  2010-5-14 下午 10:55:16  2010-5-13 下午 09:55:16

2.3、如何求两个日期的间隔时间
可以直接把两个日期相减,返回的单位为天,小时及分秒会换算成小数

SQL> select date‘2012-01-01‘-sysdate from dual;

DATE‘2012-01-01‘-SYSDATE
------------------------
        597.046030092593

2.4、如何将日期转字符
to_char(sysdate,‘YYYY-MM-DD HH24:MI:SS‘)
2.5、如何将字符转日期
to_date(‘2010-02-24 15:01:54‘,‘YYYY-MM-DD HH24:MI:SS‘)
to_timestamp(‘1999-12-01 11:00:00.123456‘,‘YYYY-MM-DD HH:MI:SS.FF6‘)

3、常用日期函数
3.1、TO_CHAR(DATE,FORMATSTR)--格式化日期成字符

SQL> select to_char(sysdate,‘YYYY-MM-DD HH24:MI:SS‘) d1 from dual;

D1
------------------------
2010-05-13 22:56:38

TO_CHAR的其它用法示例

 SQL  TO_CHAR(date , ) week_dayth, TO_CHAR(date , ) month_dayth, TO_CHAR(date , ) year_dayth, TO_CHAR(date , ) weekdayname, _(date , ) month_weekth, TO_CHAR(date , ) year_weekth  DUAL;

WEEK_DAYTH MONTH_DAYTH YEAR_DAYTH WEEKDAYNAME MONTH_WEEKTH YEAR_WEEKTH
---------- ----------- ---------- ----------- ------------ -----------
6          12          043        FRIDAY      2            07

3.2、TO_DATE(CHAR,FORMATSTR) --将字符转换成日期
to_date(‘2010-02-24 15:01:54‘,‘YYYY-MM-DD HH24:MI:SS‘)
格式备注:
HH表示12小时进制,HH24表示采用24小时进制,MM表示月份,MI表示分钟。

3.3、TRUNC(DATE)--返回DATE的日期部分,时间为0点0分0秒

SQL> select sysdate d1,trunc(sysdate) d2 from dual;

D1                       D2
------------------------ ------------------------
2010-5-13 下午 10:59:18  2010-5-13

3.4、EXTRACT(DATA FROM DATEVALUE)--返回DATE的某一部份内容
 如果DATEVALUE为DATE类型,则DATA可以是(YEAR、MONTH、DAY)
 如果DATEVALUE为TIMESTAMP类型,则DATA可以是(YEAR、MONTH,DAY、HOUR、MINUTE、SECOND)

SQL> select sysdate d1,EXTRACT(YEAR FROM sysdate) thisyear,EXTRACT(MINUTE FROM systimestamp) thism from dual;

D1                         THISYEAR      THISM
------------------------ ---------- ----------
2010-5-13 下午 11:05:06        2010          5
3.5、ADD_MONTHS(DATE,MONTHS) --在DATE增加月份得到新日期

ADD_MONTHS(sysdate,3) --当前日期加3个月
ADD_MONTHS是一个比较有意思的函数,它会自动处理大小月及闰月,如下所示

select ADD_MONTHS(date ‘2010-2-12‘, 1),
       ADD_MONTHS(date ‘2010-2-27‘, 1),
       ADD_MONTHS(date ‘2010-2-28‘, 1),
       ADD_MONTHS(date ‘2010-1-31‘, 1)
  from dual;

ADD_MONTHS(DATE‘2010-2-12‘,1) ADD_MONTHS(DATE‘2010-2-27‘,1) ADD_MONTHS(DATE‘2010-2-28‘,1) ADD_MONTHS(DATE‘2010-1-31‘,1)
----------------------------- ----------------------------- ----------------------------- -----------------------------
2010-3-12                     2010-3-27                     2010-3-31                     2010-2-28

3.6、LAST_DAY(DATE)--返回日期所在月份的最后一天日期

select LAST_DAY(date ‘2010-2-12‘) from dual;

LAST_DAY(DATE‘2010-2-12‘)
-------------------------
2010-2-28
 
3.7、NEXT_DAY(DATE,CHAR) --从给定日期开始返回下个CHAR指定星期的日期

SELECT NEXT_DAY(date‘2010-2-21‘, ‘MONDAY‘) NEXTDAY1,NEXT_DAY(date‘2010-2-22‘, ‘MONDAY‘) NEXTDAY2 FROM DUAL;

NEXTDAY1    NEXTDAY2
----------- -----------
2010-2-22   2010-3-1

TO_YMINTERVAL(CHAR)--返回[年-月]格式构成的时间间隔,一般用于日期加减运算

3.8、TO_DSINTERVAL(CHAR)--返回[天 时:分:秒]格式构成的时间间隔,一般用于日期加减运算

select date‘2010-2-12‘+TO_YMINTERVAL(‘01-02‘) newdate from dual;

NEWDATE
------------------------------
2011-4-12

3.9、NUMTOYMINTERVAL(N,CHAR) --返回CHAR中指定单位的时间间隔数值,一般用于日期加减运算
char可以为YEAR,MONTH

 date   NUMTOYMINTERVAL(, ) newdate1,
date   NUMTOYMINTERVAL(, ) newdate2
 dual;

NEWDATE1    NEWDATE2
----------- -----------
2011-2-12   2010-3-12

3.10、NUMTODSINTERVAL(N,CHAR) --返回CHAR中指定单位的时间间隔数值,一般用于日期加减运算
char可以为DAY,HOUR,MINUTE,SECOND

 date   NUMTODSINTERVAL(, ) newdate1,
date   NUMTODSINTERVAL(, ) newdate2
 dual;

NEWDATE1    NEWDATE2
----------- ------------------------
2010-2-13   2010-2-12 上午 01:00:00

时间: 2024-08-03 15:47:43

Oracle 时间类型的相关文章

oracle时间数据格式的分析

在网上看见不少oracle新学者对oracle的时间格式很烦,经常是设计了一个带时间字段的表之后,向表插入数据失败.回想起自己刚开始学习oracle时,也对这个时间格式摸不着头脑,虽然是小小的问题,高手们不屑于讨论,但对初学者来讲,这也是一个不大不小的坎,没找到门路的话, 可能几天都过不去,其实就是一层窗户纸,没什么难的.这里做一个简单的小结,因水平有限,请高手补充指正. 1 oracle对时间格式的数据存贮 oracle数据库中存放时间格式的数据,是以oracle特定的格式存贮的,占7个字节,

Oracle 时间,日期 类型函数及参数详解

ORACLE字符数字日期之间转化 Java代码 24 小时的形式显示出来要用 HH24 select to_char(sysdate,'yyyy-MM-dd HH24:mi:ss') from dual; select to_date('2005-01-01 13:14:20','yyyy-MM-dd HH24:mi:ss') from dual; to_date() function 1. 日期格式参数 含义说明 D 一周中的星期几 DAY 天的名字,使用空格填充到 9 个字符 DD 月中的第

Oracle时间日期函数

ORACLE日期时间函数大全 TO_DATE格式(以时间:2007-11-02   13:45:25为例)           Year:              yy two digits 两位年                显示值:07        yyy three digits 三位年                显示值:007        yyyy four digits 四位年                显示值:2007                    Month

oracle 时间函数

加法 select sysdate,add_months(sysdate,12) from dual; --加1年 select sysdate,add_months(sysdate,1) from dual; --加1月 select sysdate,to_char(sysdate+7,'yyyy-mm-dd HH24:MI:SS') from dual; --加1星期 select sysdate,to_char(sysdate+1,'yyyy-mm-dd HH24:MI:SS') from

Oracle数据库类型

字符类型char[(length)] 定长字符 最长2000字节varchar2[(length)] 可变长度的字符数据类型,最长4000字节NCHAR[(length)] 固定长度的字符数据类型,由国际字符语言(national language Support,NLS)字符集字符组成,最长2000字节LONG 可变长度的字符数据类型 最长2GBRAW 原始的二进制数据类型,最长2000字节long raw 原始的二进制数据类型,最长2GBrawid 数据库中一窜12字节地址,用于定位磁盘上某

【Oracle】Oracle时间日期格式

to_date("要转换的字符串","转换的格式")   两个参数的格式必须匹配,否则会报错. 即按照第二个参数的格式解释第一个参数. to_char(日期,"转换格式" ) 即把给定的日期按照"转换格式"转换. 转换的格式: 表示year的:y 表示年的最后一位 yy 表示年的最后2位 yyy 表示年的最后3位 yyyy 用4位数表示年 表示month的:mm 用2位数字表示月:mon 用简写形式 比如11月或者nov :m

Oracle 字段类型

Oracle 字段类型 http://www.cnblogs.com/lihan/archive/2010/01/06/1640547.html 字段类型 描述 字段长度及其缺省值 CHAR (size) 用于保存定长(size)字节的字符串数据. 每行定长(不足部分补为空格):最大长度为每行2000字节,缺省值为每行1字节.设置长度(size)前需考虑字符集为单字节或多字节. VARCHAR2 (size ) 用于保存变长的字符串数据.其中最大字节长度由(size)指定. 每行长度可变,最大长

ORACLE时间函数(SYSDATE)深入理解

加法 select sysdate,add_months(sysdate,12) from dual; --加1年 select sysdate,add_months(sysdate,1) from dual; --加1月 select sysdate,to_char(sysdate+7,'yyyy-mm-dd HH24:MI:SS') from dual; --加1星期 select sysdate,to_char(sysdate+1,'yyyy-mm-dd HH24:MI:SS') from

oracle时间日期处理

日期处理 时间日期类型 DATE 日期时间类型,包含的时间部分有年.月.日.时.分.秒,不包含秒的小数位和时区.合法的数据范围是January 1, 4712 BC, to December 31, 9999 AD.默认的格式是通过NLS_ DATE_FORMAT显示地设置或者通过NLS_TERRITORY隐式地设置.数据大小为固定的7位. TIMESTAMP [(fractional_seconds_precision)] 时间戳类型,包含有年.月.日.时.分.秒,并且秒可以带有精度,精度范围