zoukankan      html  css  js  c++  java
  • JAVA_java.util.Date与java.sql.Date相互转换

    在ResultSet中我们经常使用的setDate或getDate的数据类型是java.sql.Date,而在平时java程序中我们一般习惯使用 java.util.Date。因此在DAO层我们经常会碰到这俩种数据类型的相互转换,经过了一个下午的折腾,鄙人对两者的转换方法做出了小小总结,希望大家不吝指教。
    两者的关系
    java.lang.Object
        |
        +---java.util.Date
                |
                +----java.sql.Date

    从这个图中我们可以知道java.sql.Date是从java.util.Date继承过来的。

    相互转换
    1. 使用getTime()函数
    这两个类都提供了getTime()函数,用于返回对应的毫秒数(long类型)。利用这个函数可以实现转换:
        java.util.Date utilDate = new java.util.Date(sqlDate.getTime());   // sql -> util
        java.sql.Date sqlDate = new java.sql.Date(utilDate.getTime());   // util -> sql

    2. 使用SimpleDateFormat类实现转换
    SimpleDateFormat 是一个以国别敏感的方式格式化和分析数据的具体类。 它允许格式化 (date -> text)、语法分析 (text -> date)和标准化。
    SimpleDateFormat dateFormat = new SimpleDateFormate("yyyy-MM-dd HH:mm:ss");
    java.util.Date utilDate = dateFormat.parse(sqlDate.toString());

    3. 直接转换
    由于java.sql.Date是从java.util.Date中继承过来的,所以可以直接用:
    utilDate = sqlDate;

    4. 另类获得日期的方法:
    SimpleDateFormat sy=new SimpleDateFormat("yyyy");
    SimpleDateFormat sm=new SimpleDateFormat("MM");
    SimpleDateFormat sd=new SimpleDateFormat("dd");
    String syear=sy.format(date);
    String smon=sm.format(date);
    String sday=sd.format(date);

    ps: java.util.Date类中的getYear()要加上1900才可得到实际值,getMonth()则要加上1

  • 相关阅读:
    EMC、Pure和NetApp推新品,NAS闪存场景在哪里
    Tomcat 开启Gzip压缩
    win10+ubuntu双系统安装方案
    游戏中水的渲染技术系列一
    什么时候用到线程
    高并发和多线程
    angularJS双向绑定和依赖反转
    javascript ES6
    angularJS核心原理
    javascript限定输入textarea输入长度
  • 原文地址:https://www.cnblogs.com/linsond/p/1728905.html
Copyright © 2011-2022 走看看