我试图使用JPA Query获取记录,JPA Query在WHERE子句中有DATE和TIMESTAMP列.但不知何故,日期和时间戳列无法从数据库中检索任何内容.
代码段:
String sql = "Select F.* from FIN_TABLE F where F.COL1_NUM = :COL1 and F.COL2_TIMESTAMP =:COL2 and F.COL3_DATE =:COL3";
Query query = JPAentityManager.createNativeQuery(sql);
query.setParameter("COL1", 123);
//java.sql.Timestamp:2014-10-29 12:00:00.0
query.setParameter("COL2", new java.sql.Timestamp(new java.sql.Date(new SimpleDateFormat("MMM dd yyyy HH:mm:sssa").parse("OCT 29 2014 12:00:000AM").getTime()).getTime()));
//java.sql.Date:2014-10-29
query.setParameter("COL3", new java.sql.Date(new SimpleDateFormat("MMM dd yyyy HH:mm:sssa").parse("OCT 29 2014 12:00:000AM").getTime()));
List<FinTable> result = (List<FinTable>)query.getResultList();
Run Code Online (Sandbox Code Playgroud)
Oracle中的数据是:
COL1_NUM COL2_TIMESTAMP COL3_DATE 123 29-OCT-14 12.00.00.000000000 AM 26-Nov-14 456 29-OCT-14 12.00.00.000000000 AM 26-Nov-14
我最初尝试使用EntityManager.find(Class,Object)检索结果,但它也失败了所以我尝试使用createNativeQuery(),但也无法成功.我的FinTable实体将这些列作为时间戳和日期.
请指教正确的方法.:) 谢谢 !!