java中的日期和sql中的日期轉換以及java.util.Date, java.util.Calendar, java.sql.Date, java.sql.Time, java.sql.Timestamp區別和聯系


將"yyyy-mm-dd"格式的字符串轉換為java.sql.Date:

SimpleDateFormat bartDateFormat =   new SimpleDateFormat("yyyy-MM-dd");  
String dateStringToParse = "2007-7-12";  
try{  
       java.util.Date date = bartDateFormat.parse(dateStringToParse);  
       java.sql.Date sqlDate = new java.sql.Date(date.getTime());
       System.out.println(sqlDate.getTime());  
 
catch (Exception ex) {  
     System.out.println(ex.getMessage());  
}

 

java.util.Date, java.util.Calendar, java.sql.Date, java.sql.Time, java.sql.Timestamp區別和聯系:

 

在java有關的項目開發工作中,我們常常要java.util.Date,  java.util.Calendar,   java.sql.Date,    java.sql.Time,   java.sql.Timestamp等幾個類進行日期的處理和分析,那么這幾個函數之間有什么樣的聯系,它們又有什么區別呢?

首先來說說它們之間的關系,java.util.Date這個類是java.sql.Date,  java.sql.Time,  java.slq.Timestamp這三個類的父類。這三個類對java.util.Date類進行了包裝。

java.sql.Date類屏蔽了java.util.Date類的時間有關的方法(形如:hh:mm:ss),因此,不可以通過這個類訪問時間有關的信息,比如,如果你通過sqlDate.getHour()方法去訪問小時信息,此方法會拋出一個IllegalArgumentException異常。這是因為java.sql.Date在繼承java.util.Date類的時候對父類進行了重寫,禁用了時間訪問的方法。之所以這么處理,是為了和數據庫的Date數據類型相匹配,數據庫的Date數據類行只是保存日期有關的字段。

Java.sql.Time類屏蔽了java.util.Date的日期有關的字段(形如:yyyy-MM-dd),因此,不能通過這個類訪問日期有關的信息,比如:如果你通過sqlTime.getYear()方法去獲取年有關的信息,此方法會拋出一個IllegalArgumentException異常。這是因為java.sql.Time在繼承java.util.Date類的時候對父類進行了重寫,禁用了日期訪問的方法。之所以這么處理,是為了和數據庫的Time數據類型相匹配,數據庫的Time數據類行只是保存時間有關的字段。

Java.sql.Timestamp字段則對java.util.Date這個類進行了擴充,它在java.util.Date類的基礎上增加了毫秒的時間訪問控制,因此,你可以通過getNanos()方法去獲取時間的毫微秒數(注意此處獲取的時間是以毫微秒為單位的,1秒等於十億毫微秒),同樣的,這也是為了和數據庫中的Timestamp數據類型進行匹配。

理清了上述四個類的關系,那么java.util.Date和java.util.Calendar類有什么關系呢?

Java.util.Calendar類是java.util.Date類的一個更加深入,更加全面的替代。Java.util.Calendar類支持java.util.Date的所有功能,此外,Calendar還引入了多語言,多區域的特性,可以根據需要獲取不同區域,不同時區的時間,Calendar還增加了比Date更加方便和快捷的許多操作,如獲取一年當中的第幾個星期,各個月的天數等便捷的方法。

Java.util.Calendar區別與java.util.Date的幾個地方也需要注意一下:首先,Calendar增加了毫秒的時間段,通過它可以獲取時間點的毫秒值,而java.util.Date只是精確到秒。其次,Calendar過去年的時候是當前年份比如:2010,而Date獲取年份的時獲取到的是當前年份-1900的一個值(2010-1900=110,因此,你調用getYear后過去的值就是110)。最后Calendar是一個抽象類,之所以能夠實例化,是因為此處的Calendar充當了一個類似於工廠的作用,在getInstance方法中實例化了Calendar子類GregorianCalendar,並把它返回給客戶使用。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM