繁体   English   中英

JPA Criteria API-左外连接未填充@OneToMany列表

[英]JPA Criteria API - LEFT OUTER JOIN not populating a @OneToMany List

这是我的实体:

public class Patrimony {

 @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @OneToMany(mappedBy = "patrimony")
    @JsonManagedReference 
    private
    List<Patrpos> positions;
}

我的代码是:

CriteriaBuilder cb = manager.getCriteriaBuilder();

CriteriaQuery<Patrimony> cq = cb.createQuery(Patrimony.class);
Root<Patrimony> root = cq.from(Patrimony.class);

Join<Patrimony, UserProfile> userprofile = root.join(Patrimony_.userprofile);
Join<Patrimony, Patrpos> joinPatrpos = root.join(Patrimony_.positions, JoinType.LEFT);
root.fetch(Patrimony_.positions);

joinPatrpos.on(cb.equal(joinPatrpos.get(Patrpos_.dtPatrpos), dateproc.minusDays(1)));

cq.select(root);

TypedQuery<Patrimony> query = manager.createQuery(cq);

List<Patrimony> list = query.getResultList();

正在生成的查询看起来还不错,就像这样:

select
    patrimony0_.id as id1_10_0_,
    positions3_.id as id1_11_1_,
    patrimony0_.category_id as categor15_10_0_,
    patrimony0_.description as descript2_10_0_,
    patrimony0_.vl_valuation_start as vl_valu14_10_0_,
    positions3_.dt_patrpos as dt_patrp2_11_1_,
    positions3_.vl_patrpos as vl_patrp6_11_1_,
from
    patrimony patrimony0_ 
inner join
    userprofile userprofil1_ 
        on patrimony0_.userprofile_id=userprofil1_.id 
left outer join
    patrpos positions2_ 
        on patrimony0_.id=positions2_.patrimony_id 
        and (
            positions2_.dt_patrpos=?
        ) 
inner join
    patrpos positions3_ 
        on patrimony0_.id=positions3_.patrimony_id 
where userprofil1_.id=161

查询似乎正在返回我需要的所有数据,实体Patrimony返回的所有数据都正确,除了“列表位置”属性(始终为null)之外。

谢谢。

查看单元测试时,我注意到在插入测试数据后没有调用flush()和clear()。 在调用查询之前,我添加了flush和clear,所有实体均已正确填充。

谢谢大家的评论。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM