body
{
font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI",Tahoma,Helvetica,Sans-Serif,"Microsoft YaHei", Georgia,Helvetica,Arial,sans-serif,宋体, PMingLiU,serif;
font-size: 10.5pt;
line-height: 1.5;
}
html, body
{

}
h1 {
font-size:1.5em;
font-weight:bold;
}
h2 {
font-size:1.4em;
font-weight:bold;
}
h3 {
font-size:1.3em;
font-weight:bold;
}
h4 {
font-size:1.2em;
font-weight:bold;
}
h5 {
font-size:1.1em;
font-weight:bold;
}
h6 {
font-size:1.0em;
font-weight:bold;
}
img {
border:0;
max-width: 100%;
}
blockquote {
margin-top:0px;
margin-bottom:0px;
}
table {
border-collapse:collapse;
border:1px solid #bbbbbb;
}
td {
border-collapse:collapse;
border:1px solid #bbbbbb;
}

Oracle 日期类型timestamp(时间戳)和date类型使用

1、获取系统时间的语句(ssxff6获取小数点后面六位) 
select sysdate,systimestamp,to_char(systimestamp, 'yyyymmdd hh24:mi:ssxff6'), 
  to_char(systimestamp, 'yyyymmdd hh24:mi:ss.ff6') from dual;

2、字符型转成timestamp 
select to_timestamp('2011-09-14 12:52:42.123456789', 'syyyy-mm-dd hh24:mi:ss.ff') from dual;

3、timestamp转成date型 
select cast(to_timestamp('2011-09-14 12:52:42.123456789', 'syyyy-mm-dd hh24:mi:ss.ff') as date) timestamp_to_date from dual;

4、date型转成timestamp 
select cast(sysdate as timestamp) date_to_timestamp from dual;

5、两date的日期相减得出的是天数,而两timestamp的日期相减得出的是完整的年月日时分秒小数秒 
select sysdate-sysdate,systimestamp-systimestamp from dual;

select extract(day from inter) * 24 * 60 * 60 +   
  extract(hour from inter) * 60 * 60 + extract(minute from inter) * 60 +   
    extract(second from inter) "seconds" from 

  select to_timestamp('2011-09-14 12:34:23.281000000', 'yyyy-mm-dd hh24:mi:ss.ff') -   
    to_timestamp('2011-09-14 12:34:22.984000000', 'yyyy-mm-dd hh24:mi:ss.ff') inter from dual 
);

select extract(second from to_timestamp('2011-09-14 12:34:23.281000000', 'yyyy-mm-dd hh24:mi:ss.ff'))- 
  extract(second from to_timestamp('2011-09-14 12:34:22.984000000', 'yyyy-mm-dd hh24:mi:ss.ff')) from dual;

注:所以,timestamp要算出两日期间隔了多少秒,要用函数转换一下。 
to_char函数支持date和timestamp,但是trunc却不支持TIMESTAMP数据类型。 

DATE数据类型

可以存储月,年,日,世纪,时,分和秒。度量粒度是秒

以使用TO_CHAR函数把DATE数据进行传统地包装,达到表示成多种格式的目的

SELECT TO_CHAR(sysdate,'MM/DD/YYYY HH24:MI:SS') "Date" FROM dual

大多数人陷入的麻烦就是计算两个时间间的间隔年数、月数、天数、小时数和秒数。你需要明白的是,当你进行两个日期的相减运算的时候,得到的是“带小数位的天数”。

可以通过一个函数将天数转换成“天时分秒”格式:

CREATE OR REPLACE FUNCTION F_DAYS2STR(P_DAYS IN NUMBER DEFAULT 0)
    RETURN VARCHAR2 IS
    --Ver:1.0
    --Created by xsb on 2005-05-26
    --For: 将天数转换成天时分秒格式
    DAYS   NUMBER := NVL(P_DAYS, 0);
    VD     NUMBER; --天
    VH     NUMBER; --小时
    VM     NUMBER; --分
    VS     NUMBER; --秒
    RESULT VARCHAR2(100); --返回值
BEGIN
    VD := TRUNC(DAYS);
    VH := TRUNC((DAYS - VD) * 24);
    VM := TRUNC((DAYS - VD - VH / 24) * 24 * 60);
    VS := TRUNC((DAYS - VD - VH / 24 - VM / 24 / 60) * 24 * 60 * 60);
    SELECT DECODE(VD, 0, '', VD || '天') || DECODE(VH, 0, '', VH || '小时') ||DECODE(VM, 0, '', VM || '分') || DECODE(VS, 0, '', VS ||'秒')   INTO RESULT FROM DUAL;
    RETURN(RESULT);
END;

TIMESTAMP 数据类型

它包括了所有DATE数据类型的年月日时分秒的信息,而且包括了小数秒的信息。

SELECT sysdate,systimestamp FROM dual

注意,to_char函数支持date和timestamp,但是trunc却不支持TIMESTAMP数据类型。

SELECT sysdate,systimestamp,to_char(systimestamp,'yyyymmdd hh24:mi:ssxff3') FROM dual

当你直接相减的话,看看会发生什么。结果将更容易理解,

select systimestamp-systimestamp from dual

这就意味着不用再通过麻烦的计算求出多少天多少秒,用substr函数摘取出其中的数字即可!

结论:当使用date和timestamp类型的时候,选择是很清楚的。你可以随意处置date和timestamp类型。当你的时间粒度必须精确至秒以下时,可以考虑使用timestamp。

再来看如何实现:将天数转换成“天时分秒”格式:

使用DATE数据类型:

create table t2 (d1 date,d2 date) ;
INSERT INTO T2 VALUES (SYSDATESYSDATE + 1.1234);
SELECT D1, D2, D2 - D1, F_DAYS2STR(D2 - D1),
            CAST(D2 AS TIMESTAMP) - CAST(D1 AS TIMESTAMP)
    FROM T2

SELECT TO_NUMBER(SUBSTR(D21, 1, INSTR(D21, ' '))) D,
            SUBSTR(D21, INSTR(D21, ' ') + 1, 2) H,
            SUBSTR(D21, INSTR(D21, ' ') + 4, 2) M,
            SUBSTR(D21, INSTR(D21, ' ') + 7, 2) S
    FROM (SELECT CAST(D2 AS TIMESTAMP) - CAST(D1 AS TIMESTAMP) D21
           FROM T2)DATE数据类型

可以存储月,年,日,世纪,时,分和秒。度量粒度是秒

以使用TO_CHAR函数把DATE数据进行传统地包装,达到表示成多种格式的目的

SELECT TO_CHAR(sysdate,'MM/DD/YYYY HH24:MI:SS') "Date" FROM dual

大多数人陷入的麻烦就是计算两个时间间的间隔年数、月数、天数、小时数和秒数。你需要明白的是,当你进行两个日期的相减运算的时候,得到的是“带小数位的天数”。

可以通过一个函数将天数转换成“天时分秒”格式:

CREATE OR REPLACE FUNCTION F_DAYS2STR(P_DAYS IN NUMBER DEFAULT 0)
    RETURN VARCHAR2 IS
    --Ver:1.0
    --Created by xsb on 2005-05-26
    --For: 将天数转换成天时分秒格式
    DAYS   NUMBER := NVL(P_DAYS, 0);
    VD     NUMBER; --天
    VH     NUMBER; --小时
    VM     NUMBER; --分
    VS     NUMBER; --秒
    RESULT VARCHAR2(100); --返回值
BEGIN
    VD := TRUNC(DAYS);
    VH := TRUNC((DAYS - VD) * 24);
    VM := TRUNC((DAYS - VD - VH / 24) * 24 * 60);
    VS := TRUNC((DAYS - VD - VH / 24 - VM / 24 / 60) * 24 * 60 * 60);
    SELECT DECODE(VD, 0, '', VD || '天') || DECODE(VH, 0, '', VH || '小时') ||DECODE(VM, 0, '', VM || '分') || DECODE(VS, 0, '', VS ||'秒')   INTO RESULT FROM DUAL;
    RETURN(RESULT);
END;

TIMESTAMP 数据类型

它包括了所有DATE数据类型的年月日时分秒的信息,而且包括了小数秒的信息。

SELECT sysdate,systimestamp FROM dual

注意,to_char函数支持date和timestamp,但是trunc却不支持TIMESTAMP数据类型。

SELECT sysdate,systimestamp,to_char(systimestamp,'yyyymmdd hh24:mi:ssxff3') FROM dual

当你直接相减的话,看看会发生什么。结果将更容易理解,

select systimestamp-systimestamp from dual

这就意味着不用再通过麻烦的计算求出多少天多少秒,用substr函数摘取出其中的数字即可!

结论:当使用date和timestamp类型的时候,选择是很清楚的。你可以随意处置date和timestamp类型。当你的时间粒度必须精确至秒以下时,可以考虑使用timestamp。

再来看如何实现:将天数转换成“天时分秒”格式:

使用DATE数据类型:

create table t2 (d1 date,d2 date) ;
INSERT INTO T2 VALUES (SYSDATESYSDATE + 1.1234);
SELECT D1, D2, D2 - D1, F_DAYS2STR(D2 - D1),
            CAST(D2 AS TIMESTAMP) - CAST(D1 AS TIMESTAMP)
    FROM T2

SELECT TO_NUMBER(SUBSTR(D21, 1, INSTR(D21, ' '))) D,
            SUBSTR(D21, INSTR(D21, ' ') + 1, 2) H,
            SUBSTR(D21, INSTR(D21, ' ') + 4, 2) M,
            SUBSTR(D21, INSTR(D21, ' ') + 7, 2) S
    FROM (SELECT CAST(D2 AS TIMESTAMP) - CAST(D1 AS TIMESTAMP) D21
           FROM T2)

Oracle 日期类型timestamp(时间戳)和date类型使用的更多相关文章

  1. Mysql的时间戳转date类型

    mysql 的 时间戳转date类型 select FROM_UNIXTIME(1491031706235/1000,'%Y-%m-%d') from dual;

  2. SpringMVC表单或Json中日期字符串与JavaBean的Date类型的转换

    SpringMVC表单或Json中日期字符串与JavaBean的Date类型的转换 场景一:表单中的日期字符串和JavaBean的Date类型的转换 在使用SpringMVC的时候,经常会遇到表单中的 ...

  3. Oracle timestamp类型转换成date类型

    今天需要根据时间判断,统一修改某一个字段的数据.然后打开数据库发现,时间类型为timestamp类型.如下: 然后呢,这对我不是喝口水就可以解决的问题吗? 解决方案如下:我需要改这张表某个字段的内容, ...

  4. oracle中时间戳转为Date类型的数据

    问题描述: 一个表中原本应该存放date类型的数据,但是不知道之前哪位大仙把两个字段的类型建成了NUMBER类型的了,这样在后台看时间肯定不方便.现在需要改成date类型,但是现在库中是有数据的,不能 ...

  5. oracle将unix 时间戳转换为date类型

    select to_date('19700101','yyyyMMdd')+numtodsinterval(8*3600,'second')+numtodsinterval(60,'second') ...

  6. oracle 根据时间戳查询date类型sql

    话不多说上sql: select to_char(1574837126879/(1000*60*60*24)+to_date('1970-01-01 08:00:00','YYYY-MM-DD HH2 ...

  7. coding++:SpringBoot 处理前台字符串日期自动转换成后台date类型的三种办法

    第(1)种: 使用@DateTimeFormat(pattern = “yyyy-MM-dd HH:mm:ss”)注解在实体字段上. 这种方式的优点是:可以灵活的定义接收的类型 缺点很明显:不能全局统 ...

  8. springmvc/springboot处理前台字符串日期自动转换成后台date类型的三种办法

    参考https://blog.csdn.net/eumenides_/article/details/79033505 补充一个:Formatter也可以实现.

  9. js string类型时间转换成Date类型

    方法一: var t = "2015-03-16";var array =  t.split("-");var dt = new Date(array[0], ...

随机推荐

  1. Oracle错误

    System.Data.OracleClient 需要 Oracle 客户端软件 8.1.7 或更高版本 这个是我页面报的错误,请帮解答 在错误出现的时候我第一时间现在了一个oracle客户端软件,然 ...

  2. JS小知识点----基本包装类型和引用类型

    var s1 = "some text"; s1.color = "red"; alert(s1.color);  //弹出 underfined var s1 ...

  3. 深入设计模式(二)——单例模式(Singleton Pattern)

    一.单例模式介绍 单例模式(Singleton Pattern),保证一个类只有一个实例,并提供一个访问它的全局访问点.单例模式因为Singleton封装它的唯一实例,它就可以严格地控制客户怎样访问它 ...

  4. ASP.NET中设置一个定时器来定时更新 转

    asp.net 定时器 比较少用,  中国红木网这是一个相当实用的功能,有了RSS博客镜像,就不需要在多处同时发布博客日志了.比如你同时在新浪上有自己的博客,又同时有自己的个人博客站点,那么你只需要在 ...

  5. Django自定义用户认证

    自定义一个用户认证 详细参考官方文档: https://docs.djangoproject.com/en/1.9/topics/auth/customizing/#django.contrib.au ...

  6. Yii框架tips

    db组件 'schemaCachingDuration'=>3600, 为什么不起做用?需要开缓存 如何在页面下边显示sql的查询时间在log组件的routes中加入 array('class' ...

  7. 使用NppExec插件让Notepad++编译运行Java、Python

    一直希望有一个轻量级的编辑器,既可以编辑代码,也可以一键运行.后来有了NotePad++,希望可以配置配置达到目的,配Java的时候上网搜了一堆,基本上互相抄,不解决实际问题,很郁闷.后来琢磨了出来, ...

  8. Hyperic Agent 安装配置报 - No token file found, waiting for Agent to initialize

    本人经过跟VMWare 支持的多方努力,问题终于得到解决,方案如下: * Stop the agent Windows service. * Make sure all the agent proce ...

  9. HTML5实践之歌词同步播放器

    歌曲播放我们会发现他的兼容性不是很好,譬如IE上能播放的flash播放器,再firfox或者chrome上就不是很好的应用了,因为有插件的阻碍!HTML5的出现让这一切成为了可能,但是播放器虽然播放了 ...

  10. Spring 4.x org.springframework.http.converter.json.MappingJacksonHttpMessageConverter ClassNotFoundException:

    Spring 4.x The first major version of Jackson is no longer supported in Spring 4. The class you want ...