如何发现隐式多根

时间:2011-02-15 17:38:50

标签: java hibernate jpa jpa-2.0 criteriaquery

这是我的展示案例代码:

CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Tuple> q = cb.createTupleQuery();
Root<AA> aa = q.from(AA.class);

q.multiselect(aa.get("id").alias("id"),
articolo.get("a").alias("a"),
articolo.get("b").alias("b"),
articolo.get("c").get("t").alias("c"),
articolo.get("d").alias("d"));

System.out.println("RootCount: "+q.getRoots().size());

Query query = em.createQuery(q);
List<Tuple> list = query.getResultList();

其中AA是映射表,c是CC类型项(CC是另一个映射表):

好吧,我不允许插入图片,所以:Tables Schema

c是引用表CC

的外键

因此,上面的代码将打印“RootCount:1”(只有一个根),但生成的查询将是这样的:

select aa.id, aa.a, aa.b, cc.t, aa.d from AA aa, CC cc where aa.c=cc.id

所以...两个根,但q.getRoots()仅报告我明确定义的那个。

我如何才能获得真正的根源?

1 个答案:

答案 0 :(得分:2)

你只有一个根。也就是说,没有什么可以阻止你声明多个根,并手动加入它们。

Root<AA> aa = query.from(AA.class)
Path<CC> aaToCc = aa.get("c");
Root<CC> cc = query.from(CC.class)

cb.where(cb.equal(aaToCcId, cc));

诀窍是,你真的不需要CC根。您可以使用teh Path<CC>,就像根一样。或者,您可以使用aa.join