Это моя ситуация, у меня есть два основных POJO, которые я дал простому отображению гибернации:
Person
- PersonId
- Name
- Books
Book
- Code
- Description
Мой SQL-запрос возвращает строки, которые выглядят так:
PERSONID NAME CODE DESCRIPTION
-------- ---------- ---- -----------
1 BEN 1234 BOOK 1
1 BEN 5678 BOOK 2
2 JOHN 9012 BOOK 3
Мой запрос гибернации выглядит так:
session.createSQLQuery("select personid, name, code, description from person_books")
.addEntity("person", Person.class)
.addJoin("book", "person.books")
.list();
Это по разделу: 18.1.3 документации гибернации:
http://docs.jboss.org/hibernate/core/3.6/reference/en-US/html/querysql.html#d0e17464
То, что я ожидаю получить в своем списке, это 2 объекта Person с содержащимися в коллекции книгами объектами книги:
List
|- Ben
| |- Book 1
| '- Book 2
'- John
'- Book 3
Что я на самом деле вижу, так это:
List
|- Object[]
| |- Ben
| | |- Book 1
| | '- Book 2
| '- Book 1
|- Object[]
| |- Ben
| | |- Book 1
| | '- Book 2
| '- Book 2
'- Object[]
|- John
| '- Book 3
'- Book 3
Кто-нибудь знает, возможно ли получить то, что я хочу, используя этот метод?