@OneToOne无法通过OpenJPA在C​​riteriaBuilder中获取

时间:2018-12-05 16:05:30

标签: java jpa openjpa

考虑以下映射

@Table(
    name = "VerkoopOrder"
)
public class VerkoopOrder implements DatabaseEntity, Auditable {

    @Id
    @Column(
        name = "VerkoopOrderId",
        nullable = false
    )
    @GeneratedValue(
        strategy = GenerationType.IDENTITY
    )
    public Long getVerkoopOrderId() {
        return this.verkoopOrderId;
    }

    @OneToOne(
        fetch = FetchType.LAZY
    )
    @JoinColumn(
        name = "BetalingsInformatieId"
    )
    public BetalingsInformatie getBetalingsInformatie() {
        return this.betalingsInformatie;
    }
}

@Table(
    name = "BetalingsInformatie"
)
public class BetalingsInformatie implements DatabaseEntity, Auditable {
    @Id
    @Column(
        name = "BetalingsInformatieId",
        nullable = false
    )
    @GeneratedValue(
        strategy = GenerationType.IDENTITY
    )
    public Long getBetalingsInformatieId() {
        return this.betalingsInformatieId;
    }

    @OneToOne(
        mappedBy = "betalingsInformatie"
    )
    public VerkoopOrder getVerkoopOrder() {
        return this.verkoopOrder;
    }
}

我正在尝试使用criteriabuilder来一对一VerkoopOrder内的BetalingsInformatie列表查询

    CriteriaBuilder builder = getEntityManager().getCriteriaBuilder();

    CriteriaQuery<VerkoopOrder> query = builder.createQuery(VerkoopOrder.class);
    Root<VerkoopOrder> verkoopOrder = query.from(VerkoopOrder.class);
    verkoopOrder.fetch(BETALINGSINFORMATIE, JoinType.LEFT);
    Join<VerkoopOrder, VerkoopOrderLijn> verkoopOrderLijnen = verkoopOrder.join(VERKOOPORDER_LIJNEN);
    verkoopOrder.fetch(VERKOOPORDER_LIJNEN);
    query.select(verkoopOrder);
    query.distinct(true);

    PredicateBuilder predicateBuilder = new PredicateBuilder(builder, verkoopOrder);

    predicateBuilder
            .addEqualPredicate(UUID, criteria.getUuid())
            .addEqualPredicate(AANKOPER_ID, criteria.getAankoperId())
            .addEqualPredicate(verkoopOrderLijnen.get(MSISDN), criteria.getMsisdn())
            .addEqualPredicate(STATUS, criteria.getStatus())
            .addEqualPredicate(verkoopOrderLijnen.get(VERVOERCONTRACT).get(VERVOERCONTRACT_ID), criteria.getVervoerContractId())
            .addDateTimeRangePredicate(TIMESTAMP_CREATED, criteria.getTimestampCreatedStart(), criteria.getTimestampCreatedEnd())
            .addDateTimeRangePredicate(TIMESTAMP_UPDATED, criteria.getTimestampUpdatedStart(), criteria.getTimestampUpdatedEnd());

    query.where(predicateBuilder.build());
    query.orderBy(builder.desc(verkoopOrder.get(TIMESTAMP_UPDATED)));

    TypedQuery<VerkoopOrder> typedQuery = getEntityManager().createQuery(query);

    List<VerkoopOrder> verkoopOrders = typedQuery.getResultList();

然而,“ betalingsInformatie字段始终为null,(您还可以看到我正在获取VerkoopOrderLijnen的列表,该列表已经可以正确填充了。我还能尝试什么来获取betalingsInformatie呢?不得不将查询中每个Betalinginformatie字段分开查询,而不是直接从查询结果中分离出来。

有人有什么见识吗?请记住,这是使用OpenJPA实现而不是休眠或eclipselink

1 个答案:

答案 0 :(得分:2)

懒惰的JPA属性可以引发异常,也可以执行应做的事情:加载另一个实体。您没有看到异常->实体必须已加载。 Null可能是正确的结果。请检查您正在加载的特定记录的联接列。我猜没有其他实体从那里映射过。