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

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;
}

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)

来自为知笔记(Wiz)

时间: 2024-10-13 21:18:24

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

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

SpringMVC表单或Json中日期字符串与JavaBean的Date类型的转换 场景一:表单中的日期字符串和JavaBean的Date类型的转换 在使用SpringMVC的时候,经常会遇到表单中的日期字符串和JavaBean的Date类型的转换, 例如,如下代码S_ROLE_QO这个bean中包含有Date类型属性,不处理就拿不到值. /** * 分页取角色列表 * @param s_ROLE_QO 角色查询条件 * @return */ @RequestMapping(value = "/

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

问题描述: 一个表中原本应该存放date类型的数据,但是不知道之前哪位大仙把两个字段的类型建成了NUMBER类型的了,这样在后台看时间肯定不方便.现在需要改成date类型,但是现在库中是有数据的,不能直接从NUMBER改为DATE.所以需要建立先创建两个DATE类型的临时字段,然后把对应字段的数据转换为Date类型的数据之后存到新字段上面,最后删除老字段,将新字段改名为老字段. 一.新建两个临时字段 ALTER TABLE CS_USER ADD (CREATEDATE1 DATE,OPERAT

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

方法一: var t = "2015-03-16";var array =  t.split("-");var dt = new Date(array[0], array[1], array[2]);//    var dtt = new Date(t.replace("-g-/", "")); 方法二: var remindTime = "2008-04-02 10:08:44";  var str =

java中String类型转换为yyyy-MM-dd的Date类型

String birthday ="2017-02-22"; SimpleDateFormat sdf = new SimpleDateFormat(("yyyy-MM-dd")); java.util.Date date = null; try { date = sdf.parse(birthday); } catch (ParseException e) { e.printStackTrace(); } System.out.println(new java.s

Oracle数据库以date类型保存日期时,Java中用哪个类对应数据库的date类型?

1. 使用JDBC操作Oracle数据库时,使用java.sql.Date类型对应数据库的date类型,此时只能保存和读取日期部分, 时间(时分秒)部分不能读取和保存:  查询结果集可以直接获取Date类型的数据:java.sql.Date date=resultSet.getDate("dateTime"): java.sql.Date类型的数据也可以直接保存到数据库或者与数据库中date类型的数据直接比较大小: 字符串的日期,则用SQL语句的转换函数 to_date('2017-4

将 javascript 中的 timestamp(时间戳) 转 c# 的 datetime类型

相信很多人在工作中都会遇到需要将 timestamp(时间戳) 转换为 datetime 类型,特别是做网站开发的时候,有时候需要将前端传递过来的 timestamp 转为 datetime 类型,而在转的过程中发现了需要注意的地方. 首先先说说在 javascript 中产生 timestamp 的方式,一般有以下几种方式: var date = new Date(); //获取timestamp var timestamp1 = date.getTime(); var timestamp2

SQL语句oracle中如何插入Date类型的数据

转:http://chwshuang.iteye.com/blog/933926 在开发的时候,经常要写条SQL语句将信息插入表中,插入的数据如果字段是date类型,就必须将date类型转换成字符串String类型在通过sql语句插入数据库.这是我字段唯一的方法,如果有高人请另赐教! 我的解决方法是用oracle中的to_date()方法,具体看下面的例子 Oracle中插入date数据代码 insert into news(ID,MSG,SEND_TIME,TIMER) Oracle中插入da

oracle10g获取Date类型字段无时分秒解决办法!

一般的数据库中,DATE字段仅仅表示日期,不包括日期信息,而Oracle数据库中的DATE数据类型是包括日期.时间的,对于不同的Oracle jdbc驱动版本,对于该问题的处理都有些区别. 最近使用 ORACLE 10G,时间字段因需求,设为了DATE类型,发现hibernate用native SQL 查询或ibatis获取result.getObject()的时候显示不了时分秒,原来是JDBC驱动自动把date映射为 java.sql.date,故截断了时分秒信息,如果你使用9i或者11g 的

JavaScript中的Date类型

ECMAScript中的Date类型是在早起Java中的java.util.Date类基础上构建的.为此,Date类型使用自UTC(Coordinated Universal Time,国际协调时间)1970年1月1日0时开始经过的毫秒数来保存日期.在使用这种数据存储格式的条件下,Date类型保存的日期能够精确到1970年1月1日之前或之后的100000000年. 要创建一个日期对象,使用new操作符合Date构造函数即可. var now = new Date(); 在调用Date构造函数而不