Java:String转换为java.sql.Timestamp

本文详细介绍了在Java中如何将String类型转换为java.sql.Timestamp类型,包括使用SimpleDateFormat进行日期解析,以及如何通过反射机制处理基本类型和其封装类之间的转换。

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.youkuaiyun.com/Handsome2013/article/details/80700637

Exception in thread "main" net.sf.jasperreports.engine.fill.JRExpressionEvalException: Error evaluating expression for source text: $F{update_time} at net.sf.jasperreports.engine.fill.JREvaluator.handleEvaluationException(JREvaluator.java:294) at net.sf.jasperreports.engine.fill.JREvaluator.evaluate(JREvaluator.java:328) at net.sf.jasperreports.engine.fill.JRCalculator.evaluate(JRCalculator.java:673) at net.sf.jasperreports.engine.fill.JRCalculator.evaluate(JRCalculator.java:641) at net.sf.jasperreports.engine.fill.JRFillElement.evaluateExpression(JRFillElement.java:1173) at net.sf.jasperreports.engine.fill.JRFillTextField.evaluateText(JRFillTextField.java:555) at net.sf.jasperreports.engine.fill.JRFillTextField.evaluate(JRFillTextField.java:540) at net.sf.jasperreports.engine.fill.JRFillElementContainer.evaluate(JRFillElementContainer.java:383) at net.sf.jasperreports.engine.fill.JRFillBand.evaluate(JRFillBand.java:548) at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillColumnBand(JRVerticalFiller.java:2613) at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillDetail(JRVerticalFiller.java:836) at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillReportStart(JRVerticalFiller.java:275) at net.sf.jasperreports.engine.fill.JRVerticalFiller.fillReport(JRVerticalFiller.java:119) at net.sf.jasperreports.engine.fill.JRBaseFiller.fill(JRBaseFiller.java:622) at net.sf.jasperreports.engine.fill.BaseReportFiller.fill(BaseReportFiller.java:414) at net.sf.jasperreports.engine.fill.JRFiller.fill(JRFiller.java:120) at net.sf.jasperreports.engine.fill.JRFiller.fill(JRFiller.java:103) at net.sf.jasperreports.engine.JasperFillManager.fill(JasperFillManager.java:530) at net.sf.jasperreports.engine.JasperFillManager.fill(JasperFillManager.java:491) at net.sf.jasperreports.engine.JasperFillManager.fillReport(JasperFillManager.java:929) at TestDB03.main(TestDB03.java:17) Caused by: java.lang.ClassCastException: Cannot cast java.sql.Timestamp to java.tim
05-29
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值