java.util.Date转换为java.sql.Date带时分秒
java.util.Date需要转换为java.sql.Date,常规的方式转换过来只可以得到年月日,如若要取得时分秒,可以用Date的子类Timestamp
Java在向数据库中插入时间的时候,常常遇到时、分、秒丢失的情况,这种情况的发生一般是由于时间日期对象使用错误造成的。
java.util.Date是不能直接插入数据库中的,虽然它包含了日期和时分秒。java.sql.Date可以直接插入数据库,但是它只有日期而没有时间;java.sql.Time可以直接插入数据库,但是它只有时间,没有日期;以上这些往往不能满足我们的需要。
如果我们要插入日期和时间,那么就要相办法来使用java.sql.Timestamp来向数据库插入。java.sql.Timestamp可包含了日前和到毫秒的时间值,在程序中,我们常常是使用的java.util.Date,所以就要有解决的方法来实现。
有如下方法将java.util.Date转化为java.sql.Timestamp
public java.sql.Timestamp getTimestamp(Date date) {
return new java.sql.Timestamp(date.getTime());
}
这样,我们可以将我们使用的java.util.Date转化,然后插入数据库,便可以解决时、分、秒丢失的问题。
以上是用工具类的方式转换,有种简便的方法就是利用注解的方式。
以下是步骤。
- 第一步:数据库中将日期类型设置为Timestamp
- 第二步:在java实体类对应属性上方添加注解:@DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
- 例:
-
@DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date startDate;
- 第三步:在get方法上添加注释:
@JsonFormat(timezone="GMT+8", pattern="yyyy-MM-dd HH:mm:ss")
- 例:
- @JsonFormat(timezone="GMT+8", pattern="yyyy-MM-dd HH:mm:ss")
-
public Date getStartDate() { return startDate; }