我正在尝试在一个模型中进行条件查询(JPA/Hibernate),该模型包含一个带有日期的列(Oracle 11G)。例如,我有
- 2009 年 1 月 13 日
- 2009 年 1 月 15 日
- 09 年 3 月 16 日
我的功能是:
public MyEntity getEntitiesFromCertainFilters(int a, int b, java.util.date c)
{
CriteriaBuilder builder = entityManager.getCriteriaBuilder();
CriteriaQuery< MyEntity > query = builder.createQuery(MyEntity.class);
Root< MyEntity > root = query.from(MyEntity.class);
query.select(root).where (
builder.equal ( root.get ( "id" ).get ( "codEstablec" ) , establecimiento),
builder.equal ( root.get ( "id" ).get ( "correlGrupo" ) , correlGrupo),
//HERE I NEED TO ADD FILTER BY C.MONTH AND C.YEAR FROM THE DATE ATTRIBUTE
);
List < MyEntity > resultList = entityManager.createQuery(query).getResultList();
return resultList.get(0);
}
如果我想按 c = "01-JAN-09" 过滤,它应该返回:
- 2009 年 1 月 13 日
- 2009 年 1 月 15 日
任何帮助将不胜感激,在此先感谢。