Java.util.date 與 java.sql.date區別和轉換

來源:互聯網
上載者:User

 

1、將java.util.Date 轉換為 java.sql.Datejava.sql.Date sd;java.util.Date ud;//initialize the ud such as ud = new java.util.Date(); sd = new java.sql.Date(ud.getTime()); 2、若要插入到資料庫並且相應的欄位為Date類型可使用PreparedStatement.setDate(int ,java.sql.Date)方法其中的java.sql.Date可以用上面的方法得到 也可以用資料庫提供TO_DATE函數比如 現有 udTO_DATE(new SimpleDateFormat().format(ud,"yyyy-MM-dd HH:mm:ss"),"YYYY-MM-DD HH24:MI:SS")注意java中表示格式和資料庫提供的格式的不同 sql="update tablename set timer=to_date('"+x+"','yyyymmddhh24miss') where ....." 這裡的x為變數為類似:20080522131223  3、如何將"yyyy-mm-dd"格式的字串轉換為java.sql.Date 方法1 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()); }  方法2String    strDate    =    "2002-08-09";   StringTokenizer    st    =    new    StringTokenizer(strDate,    "-");   java.sql.Date    date    =    new    java.sql.Date(Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()));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.使用ResultSet的getTimestamp取得資料,這樣不會產生截取問題 (這部分詳見另一篇文章:  Timestamp 基礎知識及時間大小比較) java.sql.Date 只儲存日期資料不儲存時間資料
// 會丟失時間資料
preparedStatement.setDate(1, new java.sql.Date(date.getTime()));
//可以這樣來處理
preparedStatement.setTimestamp(1, new Timestamp(new java.util.Date().getTime()));

//想要得到完整的資料,包括日期和時間,可以這樣
java.util.Date d = resultSet.getTimestamp(1);
//這樣處理更合適一些,可以避免一些潛在Timestamp 問題
java.util.Date d = new java.util.Date(resultSet.getTimestamp(1).getTime());
   往資料庫儲存的時候可以接收 java.util.Date類型 再用getTime()方法得到代表那個Date對象的long值,再以這個long值構造一個Timestamp對象 存進資料庫中。
       從存資料庫裡取的時候,可以先得到Timestamp用他的getTime()方法得到long值,再以這個long值構造一個 java.util.Date對象,這樣就可以對這個Date對象操作了。比如說 new SimpleDateFormat("yyyyy-MM-dd HH:mm:ss").format(Date)或format(Timestamp)都行~   Calendar: Calendar calendar=Calendar.getInstance(); //獲得目前時間,聲明時間變數int year=calendar.get(Calendar.YEAR); //得到年int month=calendar.get(Calendar.MONTH); //得到月,但是,月份要加上1 month=month+1; int date=calendar.get(Calendar.DATE); //獲得日期String today=""+year+"-"+month+"-"+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.