我有2个班级:
public class Car {
private Integer id;
private List<CarOrder> carOrders;
}
public class CarOrder {
private Car car;
private Long endDate;
private Long id;
}
和hibernate映射
<class entity-name="car" name="test.es.Car" table="CARS" schema="ARK_ES">
<cache usage="read-write"/>
<id name="id" column="ID">
<generator class="sequence">
<param name="sequence">ES_SEQUENCE</param>
</generator>
</id>
<bag name="carOrders" inverse="true" lazy="true">
<cache usage="read-write"/>
<key column="CAR_ID"/>
<one-to-many not-found="ignore" entity-name="carOrder"/>
</bag>
</class>
<class entity-name="carOrder" name="temp.es.CarOrder" table="CAR_ORDERS" schema="ARK_ES">
<cache usage="read-write"/>
<id name="id" column="ID">
<generator class="sequence">
<param name="sequence">ES_ORDER_SEQUENCE</param>
</generator>
</id>
<property name="endDate" column="END_DATE"/>
<many-to-one name="car" entity-name="car">
<column name="CAR_ID"/>
</many-to-one>
</class>
我需要在endDate大于某个值的情况下加载所有汽车和汽车订单。此外,我需要缓存汽车订单的查询。我试图使用hibernate过滤器,但它们不是缓存的。是否可以使用hibernate api实现这一点而无需自定义查询? 我忘记提到汽车没有订单,但必须是结果。
感谢。
答案 0 :(得分:0)
因此,您可以在集合类中使用@fitler和@filterdef注释。但是,在会话中启用过滤器非常重要。请按照此链接了解如何启用过滤器,默认情况下不启用它们。 How to enable hibernate filter for sessionFactory.getCurrentSession()?