Oracle数据库date类型与Java中Date的联系与转化

以下是对Java中的日期对象与Oracle中的日期之间的区别与联系做点说明,以期对大家有所帮助。
new Date():分配 Date 对象并初始化此对象,以表示分配它的时间(精确到毫秒),就是系统当前。
new Date(long date) : 分配 Date 对象并初始化此对象,以表示自从标准基准时间
    (称为“历元(epoch)”,即 1970 年 1 月 1 日 00:00:00 GMT)以来的指定毫秒数。
long getTime() :返回自 1970 年 1 月 1 日 00:00:00 GMT 以来此 Date 对象表示的毫秒数。
String toString() :把此 Date 对象转换为以下形式的 
    String: dow mon dd hh:mm:ss zzz yyyy 
    其中: dow 是一周中的某一天 (Sun, Mon, Tue, Wed, Thu, Fri, Sat)。
  
*****************************************
static Calendar getInstance() :使用默认时区和语言环境获得一个日历。 
 Date getTime() 返回一个表示此 Calendar 时间值(从历元至现在的毫秒偏移量)的 Date 对象。 
long getTimeInMillis() :返回此 Calendar 的时间值,以毫秒为单位。 
void setTime(Date date) :使用给定的 Date 设置此 Calendar 的时间。 
void setTimeInMillis(long millis) :用给定的 long 值设置此 Calendar 的当前时间值。

**** *************************************
new SimpleDateFormate("yyyy-MM-dd hh:mm:ss").format(new Date());返回String类对象

总结:
1、获得系统当前时间
    获得long型: System.currentTimeMillis()
    获得Data型:new Data();
    获得Calendar型:
            Calendar c = Calendar.getInstance();
            c.setTime(System.currentTimeMillis();
    通常获得Calendar后,可以对各个字段进操作;
2、时间的各种类型之间的转换:
    Calendar 到Date:c.getTime() 返回一个Date对象
    Date 到 Calendar:c.setTime():返回一个Calendar对象
3、关于数据库中时间的存储对象
    (1)表示日期和时间的DATA类型,DATA字段中存储的值包含有与世纪、年、月、日、小时、分钟、和秒相对应的“组成部分”,它通过不同的方法显示和操作,它有效地独立于任何塔顶字符串格式
    (2)从Oracle 9i开始提供TIMESTAMP类型是DATE类型的有效扩展形式,它提供更大的时间精度,支持多大九位的小孩,同时还能存储时区信息
    (3)从Oracle 9i开始INTERVAL类型,它支持存储时间差,并且可以与DATE或者TIMESTAMP加法运算以生成一个新的DATE或者TIMESTAMP

使用SYSDATE选择当前的系统时间,返回DATE类型的值,是数据库所在的操作系统的当前日期和时间
    DATE类型的内部表示形式:执行select DUMP(sysdate) from dual;
    Typ=13 Len=8: 218,7,3,23,11,27,11,0 结果中逗号分割的值对应于Oracle存储日期和时间的每个部分,(从世纪到秒)所使用的字节
4、DATE对象与字符串之间进行转换
    TO_DAT()和TO_CHAR():这两个函数都有三个参数,一个是要转化的值,一个是可选的格式掩码和一个用于指定语言的可选字符串
    to
        select to_char(sysdate, ‘YYYY-MM-DD HH24:MI:SS‘) from dual;
        select to_date(‘20100323‘,‘YYYYMMDD‘) from dual;
        select ename, to_char(hiredate,‘ddthMon,YYYY‘) from emp
        where hiredate between 
        to_date(‘1980-01-01‘,‘YYYY-MM-DD‘)
        and
        to_date(‘1985-01-01‘,‘YYYY-MM-DD‘)
5、常用操作
    把程序的数据存到数据库中:
        当程序中是String 类型时,SQL文应该用上
        to_date(hiredate,‘yyyy-mm-dd hh24:mi:ss‘)这样放到数据库中就是date类型
        当程序中是Date类型时,必须先转为String类型,利用
        new SimpleDateFormate("yyyy-MM-dd hh:mm:ss").format(new Date())转化
    把数据库中数据取出时
        要使用to_char(hiredate,‘YYYY-MM-DD HH24:MI:SS‘)变为String类型,
        还可以继续利用java.sql.Date.valueOf(String s)
        将 JDBC 日期转义形式的字符串转换成 Date 值。 
6、取得Oracle数据库时间并存到Java中
    从数据库date取得并转为java.util.Date类型
    方法一: select to_char(sysdate, ‘YYYY-MM-DD HH24:MI:SS‘) as current_time from dual 取得字符串
    DateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");  
    String dateString = format.parse(map.get("CURRENT_TIME"));解析后取得Date的类型: Sat Jul 03 13:32:46 CST 2010
    format.format(dateString);然后再格式化成想要的格式字符串
    format.format(dateString);将Date类型转为想要的格式。但是类型为String。在想变回来时在用parse()方法.
    方法一: select (sysdate - 8 / 24 - to_date(‘1970-01-01‘, ‘yyyy-mm-dd‘)) * 86400000 current_milli from dual 取得java.math.BigDecimal类型
        BigDecimal b = (BigDecimal)dateMap.get("CURRENT_MILLI");
        Long dateLong = b.longValue();
        new Date(dateLong);取得Date对象,可以处理

Oracle数据库date类型与Java中Date的联系与转化

时间: 2024-10-11 05:20:54

Oracle数据库date类型与Java中Date的联系与转化的相关文章

Date, TimeZone, MongoDB, java中date的时区问题

打印new Date(),Fri Aug 12 13:37:51 CST 2016. 显示Asia/Shanghai的时区,但是date toString 的时区简写却是CST.更坑爹的是,Google CST结果出来是Central Standard Time. 表示North American Central Standard Time. 还以为jdk的date类有问题,debug date toString发现确实是将Asia/Shanghai的name 简写成CST. 接着google,

java中Date类型的一些操作

一.日期的比较 1.直接 用getTime 方法 时间的毫秒数比较 if(date.getTime() < start.getTime()) { return String.valueOf(Long.parseLong(year)-1); } else { return year; } 2. Date实现了Comparable接口,直接使用compareTo方法比较就ok if(date.compareTo(start) < 0) { return String.valueOf(Long.pa

向数据库中插入一个DateTime类型的数据到一个Date类型的字段中,需要转换类型。TO_DATE(&#39;{0}&#39;,&#39;YYYY-MM-DD&#39;))

需要指出的是,C#中有datetime类型,但是这个类型是包括小时,分钟,秒的.这个格式与数据库中的Date类型不符,如果将now设为datetime类型插入数据会失败. 需要通过TO_DATE('字段','YYYY-MM-DD'))转换.如下: string.Format("insert into tablename (TIME) values(TO_DATE('{0}','YYYY-MM-DD'))",now) 错误写法: string.Format("insert in

Java中Date类型详解

一.Date类型的初始化 1. Date(int year, int month, int date); 直接写入年份是得不到正确的结果的. 因为java中Date是从1900年开始算的,所以前面的第一个参数只要填入从1900年后过了多少年就是你想要得到的年份. 月需要减1,日可以直接插入. 这种方法用的比较少,常用的是第二种方法. 2. 这种方法是将一个符合特定格式,比如yyyy-MM-dd,的字符串转化成为Date类型的数据. 首先,定义一个Date类型的对象 Date date = nul

Java中Date各种相关用法

Java中Date各种相关用法(一) 1.计算某一月份的最大天数 Java代码 Calendar time=Calendar.getInstance(); time.clear(); time.set(Calendar.YEAR,year); time.set(Calendar.MONTH,i-1);//注意,Calendar对象默认一月为0 int day=time.getActualMaximum(Calendar.DAY_OF_MONTH);//本月份的天数 注:在使用set方法之前,必须

Java中Date和Calender类的使用方法

查看文章     2009-10-04 20:49 Date和Calendar是Java类库里提供对时间进行处理的类,由于日期在商业逻辑的应用中占据着很重要的地位,所以在这里想对这两个类进行一个基本的讲解,由于技术有限,不到之处请指正. Date类顾名思义,一看就知道是和日期有关的类了,这个类最主要的作用就是获得当前时间了,然而这个类里面也具有设置时间以及一些其他的功能,可是由于 本身设计的问题,这些方法却遭到众多批评,而这些遭受批评的功能都已移植到另外一个类里面,这就是今天要讲到的第二个类Ca

字符串转换成java.util.date类型和将java.util.date类型转换成java.sql.date类型

//将字符串转换成java.util.date类型 DateFormat format = new SimpleDateFormat("yyyyMMDD"); Date date1 = format.parse(startDate); //将java.util.date类型转换成java.sql.date类型 skg.statStartTime = new java.sql.Date(date1.getTime()); skg.statEndTime = new java.sql.Da

怎样将java.util.Date转化为java.sql.Date

做毕设的时候,一字段,在MySQL数据库中是date类型,后台处理是java.sql.Date类型,但是从页面上获取到的是字符串 处理: import java.text.SimpleDateformat; SimpleDateFormat sft = new SimpleDateFormat("yyyy-MM-dd"); sft.parse(request.getParameter("pub_time"));//这个解析后的日期类型为java.util.Date

javascript 的Date 格式化, 模仿shell中date命令的格式

原文:javascript 的Date 格式化, 模仿shell中date命令的格式 shell 中显示当前的日期 [[email protected]]$ date '+%Y-%m-%d %H:%M:%S' 2015-01-19 16:24:58 把javascript 中的Date object 格式化成适合的字符串,很不方便,模拟shell中的格式 下面先用3段简单的代码来说明模拟函数中用到的特性 字符串的replace var a = '1234' undefined a.replace