java timestamp转string_Java:String和Date、Timestamp之间的转换

一、String与Date(java.util.Date)互转

1.1 String -> Date

Java代码

String dateStr ="2010/05/04 12:34:23";

Date date =newDate();

//注意format的格式要与日期String的格式相匹配

DateFormat sdf =newSimpleDateFormat("yyyy/MM/dd HH:mm:ss");

try{

date = sdf.parse(dateStr);

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

}catch(Exception e) {

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

Java代码

String dateStr ="";

Date date =newDate();

//format的格式可以任意

DateFormat sdf =newSimpleDateFormat("yyyy/MM/dd HH:mm:ss");

DateFormat sdf2 =newSimpleDateFormat("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();

}

二、String与Timestamp互转

2.1 String ->Timestamp

使用Timestamp的valueOf()方法

Java代码

Timestamp ts =newTimestamp(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

Java代码

Timestamp ts =newTimestamp(System.currentTimeMillis());

String tsStr ="";

DateFormat sdf =newSimpleDateFormat("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();

}

很容易能够看出来,方法一的优势在于可以灵活的设置字符串的形式。

三、Date( java.util.Date )和Timestamp互转

声明:查API可知,Date和Timesta是父子类关系

3.1 Timestamp -> Date

Java代码

Timestamp ts =newTimestamp(System.currentTimeMillis());

Date date =newDate();

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值