私は JPA を初めて使用し、特定のクエリを理解する際に問題が発生しました。CriteriaQuery に書き直しましたが、結果と SQL に変換されたクエリが正しくありません。
背景の状況: ストア トランザクション (移動) のテーブルがあり、ストア内の現在の金額はすべての変更の合計として定義されます。ここで、最後の動きを選択して表示したいと思います。これには、店舗での結果の金額に関する情報も含まれているためです。
したがって、これは JPQL のクエリです。
SELECT m FROM move m WHERE m.id = (
SELECT MAX(o.id) FROM move o WHERE (o.item = m.item AND m.cell.store = :s)
次の CriteriaQuery に書き直そうとしました。
CriteriaBuilder builder = model.getCriteriaBuilder();
CriteriaQuery<Move> query = builder.createQuery(Move.class);
Root<Move> root = query.from(Move.class);
Subquery<Long> subquery = query.subquery(Long.class);
Root<Move> subroot = subquery.from(Move.class);
subquery.select(builder.max(subroot.get("id").as(Long.class)));
subquery.where(builder.and(
builder.equal(
subroot.get("item").get("id"),
root.get("item").get("id")),
builder.equal(
subroot.get("cell").get("store").as(Store.class),
store)));
Expression<Boolean> where = builder.equal(
root.get("id"),
subquery);
query.where(where);
return model.getList(query);
生成される誤った SQL クエリは次のとおりです。
SELECT t0.id, (...) FROM move t0 WHERE (t0.id = (
SELECT MAX(t1.id) FROM item t3, item t2, move t1
WHERE (((t2.id = t3.id) AND
(t1.cell_store = ?)) AND
((t2.id = t1.item_ref) AND
(t3.id = t0.item_ref))))
)
サブクエリに二重交差結合がある理由がわかりません。助けてくれてありがとう!