java.util.Date與java.sql.Date的關係和轉換方法(轉)

來源:互聯網
上載者:User

標籤:

在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

 

java.util.Date和java.sql.Date的區別

在除了SQL語句的情況下面使用java.sql.Date,它是針對SQL語句使用的,它只包含日期而沒有時間部分。
它都有getTime方法返回毫秒數,自然就可以直接構建
java.util.Date d = new java.util.Date(sqlDate.getTime());


java.util.Date 是 java.sql.Date 的父類(注意拼字)
前者是常用的表示時間的類,我們通常格式化或者得到目前時間都是用他
後者之後在讀寫資料庫的時候用他,因為PreparedStament的setDate()的第2參數和ResultSet的getDate()方法的第2個參數都是java.sql.Date 
轉換是
java.util.Date d=new java.util.Date (sqldate.getTime());
反過來是一樣的

 

java.util.Date和java.sql.Date的異同
       java.sql.Date,java.sql.Time和java.sql.Timestamp三個都是java.util.Date的子類(封裝類)。

       但是為什麼java.sql.Date類型的值插入到資料庫中Date欄位中會發生資料截取呢?

       java.sql.Date是為了配合SQL DATE而設定的資料類型。“正常化”的java.sql.Date只包含年月日資訊,時分秒毫秒都會清零。格式類似:YYYY-MM-DD。當我們調用ResultSet的getDate()方法來獲得傳回值時,java程式會參照"規範"的java.sql.Date來格式化資料庫中的數值。因此,如果資料庫中存在的非正常化部分的資訊將會被劫取。

       在sun提供的ResultSet.java中這樣對getDate進行注釋的:
       Retrieves the of the designated column in the current row of this <code>ResultSet</code> object as a “java.sql.Date” object in the Java programming language.

        同理。如果我們把一個java.sql.Date值通過PrepareStatement的setDate方法存入資料庫時,java程式會對傳入的java.sql.Date正常化,非正常化的部分將會被劫取。然而,我們java.sql.Date一般由java.util.Date轉換過來,如:java.sql.Date sqlDate=new java.sql.Date(new java.util.Date().getTime()).
顯然,這樣轉換過來的java.sql.Date往往不是一個規範的java.sql.Date.要儲存java.util.Date的精確值,我們需要利用java.sql.Timestamp.

java.sql.Time sTime=new java.sql.Time(utilDate.getTime());

java.sql.Timestamp stp=new java.sql.Timestamp(utilDate.getTime());

 

另外,插入資料庫時的時間類型:


datetime。對應於java中的Timestamp。內包含日期和時間。用new Timestamp(System.currentTimeMillis())來得到;

java.util.Date與java.sql.Date的關係和轉換方法(轉)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.