Hibernate映射中 date类型 和 javabean里的java.util.Date变Timestamp的问题

 

近期写了一个增删改查的东东,其中修改功能涉及到时间的比较,这个地方发现了一个问题,这个问题在我们的开发环境不存在,但是经过版本管理员发布int之后就出来了。后来发现这个确实也涉及到jdk版本的问题,但是确实也是个问题。

首先,在数据库里定义的该时间字段类型是date类型,Hibernate里.hbm.xml文件中orm映射的是 java.util.Date,javabean里也是java.util.Date,hbm.xml里的代码如下:

       <property name="tBedinDate" type="java.util.Date">
            <column name="T_BEDIN_DATE" length="7">
                <comment>起期</comment>
            </column>
        </property>
        <property name="tEndDate" type="java.util.Date">
            <column name="T_END_DATE" length="7">
                <comment>止期</comment>
            </column>
        </property>

当修改功能进行操作时,从页面传入后台的数据跟从数据库里的查询出来的数据进行比较,由于这两个时间字段是必输字段,我直接用了java.util.Date的compareTo函数来进行比较,这个是问题所在,在jdk1.5版本之后的jdk进行编译,就会出现问题。

//            if(objOld.gettEndDate().compareTo(obj.gettEndDate())!=0){
//                objOld.settEndDate(obj.gettEndDate());
//            }

后来我分析了问题所在:首先从数据库里查询的这个时间字段的类型,已经被Hibernate默认转化为:java.sql.Timestamp类型,而从数据获取的数据经过在页面展示之后,传回来的时间字段则是正常的javabean里定义的java.util.Date类型,在使用compareTo进行比较的时候会抛出异常,因为这已经是两个不同的类型在比较了。

这个问题的解决方法有好几种吧,可以把Timestamp转成Date, 也可以把Date转成Timestamp,然后比较,我用的方法是直接把两个时间字段都转化成固定格式的String,然后进行比较。

1、都转成String  再比较:

String tEndDate = new SimpleDateFormat("yyyy-MM-dd").format(objOld.gettEndDate());
            String tEndDateNew = new SimpleDateFormat("yyyy-MM-dd").format(obj.gettEndDate());
            if(!tEndDate.equals(tEndDateNew)){
                objOld.settEndDate(obj.gettEndDate());
            }

2、Timestamp转成Date

Timestamp t = new Timestamp(System.currentTimeMillis());  
Date d new Date(t.getTime()); 

 

3、Date转成Timestamp

//SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd:HH:mm:ss");
String tsStr = new SimpleDateFormat("yyyy-MM-dd:HH:mm:ss").format(objOld.gettEndDate());
Timestamp ts
= Timestamp.valueOf(tsStr);

或者  用new Timestamp((new Date()).getTime())  ,这个还没有试过。

关于为什么从数据库里查询的这个时间字段的类型会被Hibernate默认转成Timestamp类型,查了不少资料,都没有能给出让人信服的理由的,

在查资料的时候,发现了几篇看着挺不错的文章,可以学习下:

 java.util.Date、java.sql.Date、java.sql.Time、java.sql.Timestamp区别和总结: http://blog.youkuaiyun.com/xiancaieeee/article/details/8099184

JDK 1.4升级至JDK5 JDK6的两个关键问题BigDecimal、java.sql.Date   :  http://shuwen.iteye.com/blog/1179826

 

转载于:https://www.cnblogs.com/sunny20082870/p/6397038.html

### 解决方案 在Java Spring框架中,当尝试将字符串类型的时间参数转换为`Date`类型时出现错误,通常是因为格式不匹配或缺少必要的转换器配置。以下是解决此问题的详细方法: #### 1. 配置`MappingJackson2HttpMessageConverter` 确保Spring应用的类路径中包含Jackson库,并正确配置了`MappingJackson2HttpMessageConverter`。该转换器负责处理JSON与对象之间的转换[^2]。如果未正确配置,可能导致时间格式解析失败。 ```java @Configuration public class WebConfig implements WebMvcConfigurer { @Override public void configureMessageConverters(List<HttpMessageConverter<?>> converters) { MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter(); ObjectMapper objectMapper = new ObjectMapper(); objectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false); objectMapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")); // 设置日期格式 converter.setObjectMapper(objectMapper); converters.add(converter); } } ``` #### 2. 使用自定义日期格式注解 在需要接收时间参数的字段上添加`@JsonFormat`注解以指定日期格式。例如: ```java public class FinanceTableData { @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") private Date financeTableDataEnd; // Getter and Setter public Date getFinanceTableDataEnd() { return financeTableDataEnd; } public void setFinanceTableDataEnd(Date financeTableDataEnd) { this.financeTableDataEnd = financeTableDataEnd; } } ``` 此方法确保传入的字符串能够按照指定格式正确解析为`Date`类型。 #### 3. 实现自定义`RowMapper` 如果涉及数据库操作且需要将结果映射JavaBean,则可以使用`BeanPropertyRowMapper`。确保目标类遵循JavaBean规范并正确设置日期格式[^3]。例如: ```java public List<FinanceTableData> getFinanceData() { String sql = "SELECT * FROM finance_table WHERE finance_table_data_end <= ?"; BeanPropertyRowMapper<FinanceTableData> rowMapper = new BeanPropertyRowMapper<>(FinanceTableData.class); return jdbcTemplate.query(sql, new Object[]{new java.sql.Date(System.currentTimeMillis())}, rowMapper); } ``` #### 4. 捕获并处理异常 为了提高系统的健壮性,可以在控制器层捕获并处理日期转换异常。例如: ```java @ExceptionHandler(MethodArgumentTypeMismatchException.class) public ResponseEntity<String> handleMethodArgumentTypeMismatchException(MethodArgumentTypeMismatchException ex) { return new ResponseEntity<>("Invalid date format. Expected format: yyyy-MM-dd HH:mm:ss", HttpStatus.BAD_REQUEST); } ``` #### 5. 测试接口 在Postman或其他工具中测试接口时,确保传递的时间参数符合预期格式(如`yyyy-MM-dd HH:mm:ss`)。可以通过以下方式验证: - **Pre-request Script**:生成符合格式的时间参数。 - **环境量**:存储并复用时间参数。 示例代码如下: ```javascript var moment = require('moment'); var formattedTime = moment().format("YYYY-MM-DD HH:mm:ss"); pm.globals.set("TIME", formattedTime); ``` 在请求中引用全局量`{{TIME}}`即可传递格式化后的时间[^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值