JPA select 带有时间戳和日期字段的查询无法检索结果
JPA select query with timestamp and date fields fail to retrieve results
我正在尝试使用 JPA 查询获取记录,该查询在 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();
而 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 实体将这些列作为时间戳和日期。
请指教正确的方法。 :)
谢谢!!
日期和日历参数值需要特殊方法才能指定它们代表什么,例如纯日期、纯时间或日期和时间的组合,如日期和时间(时间)中详细解释类型部分。
例如,以下调用将 Date 对象作为纯日期(无时间)传递:
query.setParameter("date", new java.util.Date(), TemporalType.DATE);
和时间戳
query.setParameter("date", new java.util.Date(), TemporalType.TIMESTAMP);
感谢您的回复。
问题已解决。
我正确地使用了 DATE 和 TIMESTAMP 对象。
50% 的问题出在 SimpleDateFormat 解析上,我在其中提到了 24 小时格式 (HH) 和 AM/PM,正确使用的解析器是...
"MMM dd yyyy hh:mm:sssa" //OCT 29 2014 12:00:000AM
而不是...
"MMM dd yyyy HH:mm:sssa" //OCT 29 2014 00:00:000
其余 50% 的问题与列 COL3_DATE 有关,该列被错误地定义为 DATE,但最初是 TIMESTAMP;将其更改为 TIMESTAMP 解决了问题。
但是,使用日期仍然是任何方法的问题(java.sql.Date、java.util.Date 和 Temporal.DATE)。
感谢您的贡献。 :)
我正在尝试使用 JPA 查询获取记录,该查询在 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();
而 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 实体将这些列作为时间戳和日期。
请指教正确的方法。 :) 谢谢!!
日期和日历参数值需要特殊方法才能指定它们代表什么,例如纯日期、纯时间或日期和时间的组合,如日期和时间(时间)中详细解释类型部分。
例如,以下调用将 Date 对象作为纯日期(无时间)传递:
query.setParameter("date", new java.util.Date(), TemporalType.DATE);
和时间戳
query.setParameter("date", new java.util.Date(), TemporalType.TIMESTAMP);
感谢您的回复。 问题已解决。
我正确地使用了 DATE 和 TIMESTAMP 对象。
50% 的问题出在 SimpleDateFormat 解析上,我在其中提到了 24 小时格式 (HH) 和 AM/PM,正确使用的解析器是...
"MMM dd yyyy hh:mm:sssa" //OCT 29 2014 12:00:000AM
而不是...
"MMM dd yyyy HH:mm:sssa" //OCT 29 2014 00:00:000
其余 50% 的问题与列 COL3_DATE 有关,该列被错误地定义为 DATE,但最初是 TIMESTAMP;将其更改为 TIMESTAMP 解决了问题。
但是,使用日期仍然是任何方法的问题(java.sql.Date、java.util.Date 和 Temporal.DATE)。
感谢您的贡献。 :)