gpt4 book ai didi

java - Hibernate @Filter 在 JPA 中不起作用?

转载 作者:搜寻专家 更新时间:2023-10-31 19:55:10 25 4
gpt4 key购买 nike

我将 JPA 与 Hibernate 一起用作 JPA 提供程序。我不知道如何配置我的实体以将 hibernate 过滤器应用于一对多关联。

我有一个Master,其中包含一组Details。这是我的实体定义:

@Entity
public class Master extends Base {
private List<Detail> details;

@OneToMany
@OrderColumn
@JoinTable(name = "master_details")
@Filter(name = "notDeleted")
// @Where(clause = "deleted = 'false'")
public List<Detail> getDetails() {
return details;
}

public void setDetails(List<Detail> details) {
this.details = details;
}
}

@Entity
@FilterDef(name = "notDeleted", defaultCondition = "deleted = false")
public class Detail extends Base {
private Boolean deleted = false;

public Boolean getDeleted() {
return deleted;
}

public void setDeleted(Boolean deleted) {
this.deleted = deleted;
}
}

Base 没什么特别的,只是一个简单的 MappedSuperClass:

@MappedSuperclass
public class Base {
private Long id;

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
public Long getId() {
return id;
}

public void setId(Long id) {
this.id = id;
}
}

当通过 entityManager.find(Master.class, mid) 加载一个 Master 时,过滤器应该阻止加载所有 Details 但我检查了 hibernate 生成的 sql 查询(通过 show_sql=true)并且在加载 master 的详细信息时没有添加 where 子句! hibernate 生成的示例查询是:

select
details0_.Master_id as Master1_6_1_,
details0_.details_id as details2_1_,
details0_.details_ORDER as details3_1_,
detail1_.id as id7_0_,
detail1_.deleted as deleted7_0_,
from
master_details details0_
inner join
Detail detail1_
on details0_.details_id=detail1_.id
where
details0_.Master_id=?

经过一些搜索,有一些提示“通过 id 加载不会使用过滤器,使用查询”所以我尝试了以下但没有收获:(

entityManager.createQuery("from Master where id=" + mid).getSingleResult();

但是只要 getDetails 上面的 @Where 没有注释(而不是 @Filter),它的子句就会被添加到 hibernate 生成的查询中(但我不能使用 @Where)

最佳答案

Hibernate @Filter需要通过enableFilter方法手动激活:

session.enableFilter("myFilter").setParameter("myFilterParam", "some-value");

但是,当您需要参数化过滤条件时,过滤器很有用。而且,您似乎不需要动态过滤子句。

因此,您可以使用 Hibernate @Where 过滤器,如下所示:

@org.hibernate.annotations.Where(clause="deleted=false")        
public List<Detail> getDetails() {
return details;
}

这样,您应该得到未删除的 Detail 实体的列表。

关于java - Hibernate @Filter 在 JPA 中不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23859460/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com