это возможно с критериями Hibernate?
select A.something, B.something, C.something, D.something
from A JOIN B on A.id = B.id_fk
JOIN C ON B.id = C.id_fk
JOIN D ON C.id = D.id_fk;
это возможно с критериями Hibernate?
select A.something, B.something, C.something, D.something
from A JOIN B on A.id = B.id_fk
JOIN C ON B.id = C.id_fk
JOIN D ON C.id = D.id_fk;
У меня точно такая же проблема, и я смог решить ее следующим образом:
return criteria.createCriteria(A.class)
.createCriteria("b", "join_between_a_b")
.createCriteria("c", "join_between_b_c")
.createCriteria("d", "join_between_c_d")
.add(Restrictions.eq("some_field_of_D", someValue));
Примечание. "b"
, "c"
и "d"
в приведенном выше коде относятся к именам атрибутов в классах A
, B
и C
соответственно (класс A
имеет атрибут b
и т. д.).
Для этого решения вам даже не нужно устанавливать параметры lazy
и fetch
в файле A.hbm.xml
.
Несколько хороших примеров можно найти в справочном материале по Hibernate которые показывают использование setFetchMode для получения ассоциаций с внешним соединением.
Пример:
List books = sess.createCriteria(Book.class)
.setFetchMode("chapters", FetchMode.EAGER)
.setFetchMode("reviews", FetchMode.EAGER)
.list();
Там также есть информация о различной выборке приемы, которые могут быть вам полезны.
D
.
- person mindas; 23.02.2011
FetchMode.EAGER
в настоящее время устарел, вместо этого используйте FetchMode.JOIN
.
- person Tim Büthe; 13.08.2019
Попробуйте установить режим выборки в ваших критериях, например:
criteria.setFetchMode(..., FetchMode.EAGER)
Это создает запрос на соединение. Более подробную информацию можно найти здесь.
Да, на самом деле есть несколько способов сделать это: