Java:String转换为java.sql.Timestamp
1.JPA映射Mysql的timestamp类型应使用java.sql.Timestamp
mysql中的timestamp类型最大长度为6,如果JPA设置的长度大于6,程序执行时控制台输出有建表提示,但是在数据库中表并没有创建成功,调试状态下能看到报错的信息。
实体类中Timestamp属性定义如下:
@Column(columnDefinition = "timestamp(6)")
private Timestamp ts;
2.String类型转换为java.sql.Timestamp
首先将String转换为java.util.Date,使用unmarshal方法。如下:
public class DateAdapter extends XmlAdapter<String,Date> {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
@Override
public Date unmarshal(String v) throws Exception {
if (!v.contains(".")){
v+=".000";
}
return sdf.parse(v);
}
@Override
public String marshal(Date v) throws Exception {
return sdf.format(v);
}
然后再将java.util.Date转换为java.sql.Timestamp,如下:
Java.util.Date dateTime = DateAdapter.unmarshal(String v);
Timestamp timestamp = new Timestamp(dateTime.getTime());
详细的JAVA中java.util.Date、java.sql.Timestamp和String之间的互相转换参考了:
https://www.cnblogs.com/zhang-yan/p/7733005.html
3. java其他类型和String类型的相互转换
有时候,为了使用类的反射机制,我们把类的属性类型定义为基本封装类,如基本数据类型的int对应的封装类为Integer。
Java 八种基本类型和基本类型封装类 参考https://www.cnblogs.com/alternative/p/7520332.html
java中String类型和基本类型的转换,以及toString的用法 参考https://blog.csdn.net/Handsome2013/article/details/80700637