0

有没有办法使用注释对类中的地图类型属性应用过滤器?我已经完成了类似下面的操作,但没有应用过滤器

public class EntityA
{
@id
@GeneratedValue
@Column(name="id")
private Long id;

@OneToMany(mappedBy="EntityA")
@MapKeyColumn(name = "entityB_id")
@Filter(name = "percentFilter", condition="MODEL_PERCENT> :percent")
private Map<Long, EntityB> entityBMap;
} 

public class EntityB
{
@Column(name = "MODEL_PERCENT")
private BigDecimal modelPercent;

@ManyToOne
@joincolumn(name="entityA_id") 
private EntityA entityA; 
}

但是,如果我将地图属性更改为如下列表,则过滤器有效

@OneToMany(mappedBy="EntityA")
@MapKeyColumn(name = "entityB_id")
@Filter(name = "percentFilter", condition="MODEL_PERCENT> :percent")
private Map<Long, EntityB> entityBMap;

@OneToMany(mappedBy="EntityA")
@JoinColumn(name = "entityA_id")
@Filter(name = "percentFilter", condition="MODEL_PERCENT> :percent")
private List<EntityB> entityBList;

所以我想我需要一些帮助来注释地图属性,以便过滤器起作用。任何建议或示例代码都会有很大帮助。谢谢。

4

1 回答 1

1

您想将过滤条件应用于关联表,因此,使用@FilterJoinTable和使用属性名称,而不是数据库列名称:

@OneToMany(mappedBy="EntityA")
@MapKeyColumn(name = "entityB_id")
@FilterJoinTable(name = "percentFilter", condition="modelPercent > :percent")
private Map<Long, EntityB> entityBMap;

检查过滤器的 Hibernate Annotations 文档,你可以找到一个例子。

希望能帮助到你。

编辑:

不要忘记在您的休眠会话中启用过滤:

session.enableFilter("percentFilter").setParameter("percent", "some-value");
于 2012-09-04T09:03:42.223 回答