java - 如何发现隐式多重根

标签 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() 只报告我明确定义的那个根。

如何获得真正的根?

最佳答案

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

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 根。您可以使用Path<CC>非常像根。或者,您可以使用 aa.join .

关于java - 如何发现隐式多重根,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5007249/

相关文章:

java - 什么是快速、等待通知或忙等待?

java - PostgreSQL 错误,类型 Java_Object 不存在

Hibernate 延迟加载和 Hazelcast

java - 遗留 Hibernate 应用程序的预期升级路径是什么?

java - PageListView 和数据集加载

java - Android WebView 在旧版 api 上同步 cookie

java - 手动处理事务而不是JtaTransactionManager

java线程同步

java - 如何将 Hibernate 验证注释与枚举一起使用?

java - PostgreSQL 使用 JPA 和 Hibernate 抛出 "column is of type jsonb but expression is of type bytea"