这是我的展示案例代码:
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() 只报告我明确定义的那个。
我怎样才能得到真正的根源?