關於String、date、Timestamp之間的相互轉換問題

    

1、String與Date(java.util.Date)互轉java

 

     1.1 String -> Datesql

 

  1. String dateStr = "2010/05/04 12:34:23";   數據庫

  2.         Date date = new Date();   spa

  3.         //注意format的格式要與日期String的格式相匹配   code

  4.         DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");   orm

  5.         try {   對象

  6.             date = sdf.parse(dateStr);   字符串

  7.             System.out.println(date.toString());   get

  8.         } catch (Exception e) {   it

  9.             e.printStackTrace();   

  10.         }  

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

  1. String dateStr = "";   

  2.         Date date = new Date();   

  3.         //format的格式能夠任意   

  4.         DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");   

  5.         DateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd HH/mm/ss");   

  6.         try {   

  7.             dateStr = sdf.format(date);   

  8.             System.out.println(dateStr);   

  9.             dateStr = sdf2.format(date);   

  10.             System.out.println(dateStr);   

  11.         } catch (Exception e) {   

  12.             e.printStackTrace();   

  13.         }  

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()方法

  1. Timestamp ts = new Timestamp(System.currentTimeMillis());   

  2.         String tsStr = "2011-05-09 11:49:45";   

  3.         try {   

  4.             ts = Timestamp.valueOf(tsStr);   

  5.             System.out.println(ts);   

  6.         } catch (Exception e) {   

  7.             e.printStackTrace();   

  8.         }  

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

 

  1. Timestamp ts = new Timestamp(System.currentTimeMillis());   

  2.         String tsStr = "";   

  3.         DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");   

  4.         try {   

  5.             //方法一   

  6.             tsStr = sdf.format(ts);   

  7.             System.out.println(tsStr);   

  8.             //方法二   

  9.             tsStr = ts.toString();   

  10.             System.out.println(tsStr);   

  11.         } catch (Exception e) {   

  12.             e.printStackTrace();   

  13.         }  

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

 

 

  1. Timestamp ts = new Timestamp(System.currentTimeMillis());   

  2.         Date date = new Date();   

  3.         try {   

  4.             date = ts;   

  5.             System.out.println(date);   

  6.         } catch (Exception e) {   

  7.             e.printStackTrace();   

  8.         }  

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()等等

相關文章
相關標籤/搜索