fetchtype 动态控制_忽略关系中的FetchType.EAGER

在大型应用程序中,我与EAGER的关系存在问题。此应用程序中的某些实体EAGER与其他实体具有关联。这在某些功能上成为“毒药”。

现在,我的团队需要优化此功能,但是 我们无法将访存类型更改为LAZY ,因为我们需要重构整个应用程序。

所以,我的问题是:是否有一种方法可以执行特定的查询而忽略我返回的实体中的EAGER关联?

示例:当我有这个实体Person时,我在查询以查找Person时不带地址列表。

@Entity

public class Person {

@Column

private String name;

@OneToMany(fetch=FetchType.EAGER)

private List address;

}

Query query = EntityManager.createQuery("FROM Person person");

//list of person without the address list! But how???

List resultList = query.getResultList();

谢谢!

更新

我发现的唯一方法是不返回实体,仅返回实体的某些字段。但是我想找到一个可以返回实体(在我的示例中为Person实体)的解决方案。

我在想是否有可能在Hibernate中两次映射同一张表。这样,我可以在没有EAGER关联的情况下映射同一张表。这在某些情况下会帮助我…

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值