Как обнаружить неявный множественный корень - PullRequest
1 голос
/ 15 февраля 2011

вот мой код показа:

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 Ответ

2 голосов
/ 28 февраля 2011

У вас есть только один корень.Тем не менее, ничто не мешает вам объявить несколько корней и вручную соединить их.

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> почти как root.Кроме того, вы можете использовать aa.join.

...