原因是Oracle jdbc驱动版本的导致,需要更换驱动版本:
ojdbc14.jar:DATE > java.sql.Date
ojdbc6.jar:DATE > java.sql.Timestamp
不更新驱动的方法:
String queryStr = "SELECT T.MDATE FROM MTABLE T";
Query query = em.createNativeQuery(queryStr);
SQLQuery sqlQuery = (SQLQuery) ((HibernateQuery) query).getHibernateQuery();
// 项目中找不到Hibernate.TIMESTAMP,可能是版本不同
// sqlQuery.addScalar("MDATE", Hibernate.TIMESTAMP);
// 改用org.hibernate.type.TimestampType类,实测可行
sqlQuery.addScalar("MDATE", new org.hibernate.type.TimestampType());
List<Object[]> resultList = query.getResultList();
本文介绍了在使用Oracle JDBC驱动时,由于驱动版本差异导致DATE类型转换问题的解决方案。通过创建NativeQuery并自定义TimestampType解决查询中的日期格式问题,确保了与不同版本驱动的兼容性。
2422

被折叠的 条评论
为什么被折叠?



