Java:String转换为java.sql.Timestamp

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值