标准 JPA 2,包含 3 个表格
2022-09-01 18:25:34
我正在尝试创建一个条件来从3个表(关联,更新和详细信息)中检索一些对象。“详细信息”引用“关联和”更新“,”更新“引用”详细信息“列表。我的目标是检索一个更新列表,该列表在给定关联 ID 的情况下,在指定字段中至少具有 null 值的详细信息。在JPQL中很容易做到,但客户说这必须用标准进行编码。
我的JPQL是:
public List<Update> getUpdates(long associateId) {
TypedQuery<Update> query = em.createQuery("select distinct u from Update u, Detail dt, Associate a "
+ "where dt.update = u and dt.associate = a and a.associateId = :id and "
+ "dt.ack_date is null", Update.class);
query.setParameter("id", associateId);
return query.getResultList();
}
我尝试了以下方法,但它只是返回了数据库中的所有更新:
public List<Update> getUpdates(long associateId) {
CriteriaBuilder builder = em.getCriteriaBuilder();
CriteriaQuery<Update> query = builder.createQuery(Update.class);
Root<Update> fromUpdates = query.from(Update.class);
Root<Associate> fromAssociate = query.from(Associate.class);
Root<Detail> fromDetail = query.from(Detail.class);
Join<Detail, Associate> associateJoin = fromDetail.join("associate");
Join<Detail, Update> updateJoin = fromDetail.join("update");
TypedQuery<Update> typedQuery = em.createQuery(query
.select(fromUpdates)
.where(builder.and(
builder.equal(fromAssociate.get("associateId"), associateId),
builder.equal(fromDetail.get("associate"), associateJoin),
builder.equal(fromDetail.get("update"), updateJoin),
builder.isNull(fromDetail.get("ack_date"))
))
.orderBy(builder.asc(fromUpdates.get("updateId")))
.distinct(true)
);
return typedQuery.getResultList();
}
任何人都可以帮我吗?我搜索了一下,但找不到任何包含3个实体的示例。