zoukankan      html  css  js  c++  java
  • PLSQL_基础系列09_时间戳记TIMESTAMP(案例)

    2013-11-09 Created By BaoXinjian

    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 数据类型。

     

    Thanks and Regards

  • 相关阅读:
    二维数组和指向指针的指针
    多路复用构建高性能服务器
    disque概要
    漫谈云计算与SOA (1)
    zeromq
    自定义内存分配
    基于行的操作
    反应器类型的操作
    多个流,简短的读和写
    缓存
  • 原文地址:https://www.cnblogs.com/eastsea/p/4154272.html
Copyright © 2011-2022 走看看