我正在尝试创建一个查询,CriteriaBuilder
用于选择所有Product
股票大于零的股票。库存是sum(DeliveryRow.amount) - sum(DispatchRow.amount)
。两者当然只包含正确的Product
。
我已经尝试Subquery
为两者创建DeliveryRow
,DispatchRow
虽然我觉得这应该使用join()
.
课程
Product {
(...)
}
DeliveryRow {
@ManyToOne
private Product product;
private int amount;
}
DispatchRow {
@ManyToOne
private Product product;
private int amount;
}
询问
在这个查询中,我不确定如何处理xxx
. 我尝试过创建子查询,但没有成功。
CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Product> query = cb.createQuery(Product.class);
Root product = query.from(Product.class);
query.select(product);
// sum of DeliveryRow.amount where DeliveryRow.product = Product
// minus
// sum of DispatchRow.amount where DispatchRow.product = Product
Expression stock = xxx;
query.where(cb.gt(stock, Integer.parseInt(0)));
return em.createQuery(query).getResultList();
关于如何解决这个问题的任何建议?