1.1 String -> Date
1 String dateStr = "2010/05/04 12:34:23"; 2 Date date = new Date(); 3 //注意format的格式要与日期String的格式相匹配 4 DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss"); 5 try { 6 date = sdf.parse(dateStr); 7 System.out.println(date.toString()); 8 } catch (Exception e) { 9 e.printStackTrace(); 10 }
1.2 Date -> String
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与Timestamp互转
2.1 String ->Timestamp
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 }
注: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 }
很容易能够看出来,方法一的优势在于可以灵活的设置字符串的形式。
三、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 }
很简单,但是此刻date对象指向的实体却是一个Timestamp,即date拥有Date类的方法,但被覆盖的方法的执行实体在Timestamp中。
3.2 Date -> Timestamp
父类不能直接向子类转化,可借助中间的String~~~~
java.sql.Date 只存储日期数据不存储时间数据
1 // 会丢失时间数据 2 preparedStatement.setDate(1, new java.sql.Date(date.getTime())); 3 //可以这样来处理 4 preparedStatement.setTimestamp(1, new java.sql.Timestamp(new java.util.Date().getTime())); 5 6 //想要得到完整的数据,包括日期和时间,可以这样 7 java.util.Date d = resultSet.getTimestamp(1); 8 //这样处理更合适一些,可以避免一些潜在Timestamp 问题 9 java.util.Date d = new java.util.Date(resultSet.getTimestamp(1).getTime()); 10 自己补的话
这样的话:
往数据库存储的时候可以接收 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()等等
Java:String和Date、Timestamp之间的转换
原文:http://www.cnblogs.com/qingxinshujuan/p/4968426.html