1、String與Date(java.util.Date)互轉java
1.1 String -> Datesql
String dateStr = "2010/05/04 12:34:23"; 數據庫
Date date = new Date(); spa
//注意format的格式要與日期String的格式相匹配 code
DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss"); orm
try { 對象
date = sdf.parse(dateStr); 字符串
System.out.println(date.toString()); get
} catch (Exception e) { it
e.printStackTrace();
}
String dateStr = "2010/05/04 12:34:23"; Date date = new Date(); //注意format的格式要與日期String的格式相匹配 DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss"); try { date = sdf.parse(dateStr); System.out.println(date.toString()); } catch (Exception e) { e.printStackTrace(); }
1.2 Date -> String
日期向字符串轉換,能夠設置任意的轉換格式format
String dateStr = "";
Date date = new Date();
//format的格式能夠任意
DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
DateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd HH/mm/ss");
try {
dateStr = sdf.format(date);
System.out.println(dateStr);
dateStr = sdf2.format(date);
System.out.println(dateStr);
} catch (Exception e) {
e.printStackTrace();
}
String dateStr = ""; Date date = new Date(); //format的格式能夠任意 DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss"); DateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd HH/mm/ss"); try { dateStr = sdf.format(date); System.out.println(dateStr); dateStr = sdf2.format(date); System.out.println(dateStr); } catch (Exception e) { e.printStackTrace(); }
2、String與Timestamp互轉
2.1 String ->Timestamp
使用Timestamp的valueOf()方法
Timestamp ts = new Timestamp(System.currentTimeMillis());
String tsStr = "2011-05-09 11:49:45";
try {
ts = Timestamp.valueOf(tsStr);
System.out.println(ts);
} catch (Exception e) {
e.printStackTrace();
}
Timestamp ts = new Timestamp(System.currentTimeMillis()); String tsStr = "2011-05-09 11:49:45"; try { ts = Timestamp.valueOf(tsStr); System.out.println(ts); } catch (Exception e) { e.printStackTrace(); }
注:String的類型必須形如: yyyy-mm-dd hh:mm:ss[.f...] 這樣的格式,中括號表示可選,不然報錯!!!
若是String爲其餘格式,可考慮從新解析下字符串,再重組~~
2.2 Timestamp -> String
使用Timestamp的toString()方法或者借用DateFormat
Timestamp ts = new Timestamp(System.currentTimeMillis());
String tsStr = "";
DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
try {
//方法一
tsStr = sdf.format(ts);
System.out.println(tsStr);
//方法二
tsStr = ts.toString();
System.out.println(tsStr);
} catch (Exception e) {
e.printStackTrace();
}
Timestamp ts = new Timestamp(System.currentTimeMillis()); String tsStr = ""; DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss"); try { //方法一 tsStr = sdf.format(ts); System.out.println(tsStr); //方法二 tsStr = ts.toString(); System.out.println(tsStr); } catch (Exception e) { e.printStackTrace(); }
很容易可以看出來,方法一的優點在於能夠靈活的設置字符串的形式。
3、Date( java.util.Date )和Timestamp互轉
聲明:查API可知,Date和Timesta是父子類關係
3.1 Timestamp -> Date
Timestamp ts = new Timestamp(System.currentTimeMillis());
Date date = new Date();
try {
date = ts;
System.out.println(date);
} catch (Exception e) {
e.printStackTrace();
}
Timestamp ts = new Timestamp(System.currentTimeMillis()); Date date = new Date(); try { date = ts; System.out.println(date); } catch (Exception e) { e.printStackTrace(); }
很簡單,可是此刻date對象指向的實體倒是一個Timestamp,即date擁有Date類的方法,但被覆蓋的方法的執行實體在Timestamp中。
3.2 Date -> Timestamp
父類不能直接向子類轉化,可藉助中間的String~~~~
java.sql.Date 只存儲日期數據不存儲時間數據
// 會丟失時間數據
preparedStatement.setDate(1, new java.sql.Date(date.getTime()));
//能夠這樣來處理
preparedStatement.setTimestamp(1, new java.sql.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 SimpleTimeFormat("yyyyy-MM-dd HH:mm:ss").format()等等