Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате |
Форум программистов > Java EE (J2EE) и Spring > JPA, использование простых классов,не persistent |
Автор: Nikola661 20.7.2010, 09:33 | ||||
Чтобы получить данные мы делаем так:
Но иногда нужно обеспечить не совсем простой вывод данных перед пользователем. Можно ли использовать свой class?? Вот так:
Выдает ошибку: типа CustomTable1 не класс персистент ентити (чо за н..х не могу на англ печатать) Тут хр. процедура store_proc(........) должна вернуть свой набор данных, который соответствует CustomTable1, который не persistent |
Автор: ki6opr 20.7.2010, 09:55 |
ну а просто в цикле пройти по результату и завернуть в обертку ? PS просто если Вы нигде маппинг не настроили то вам вернется просто список каждый элемент которого массив с вашим результатом. как бы ORM он не ясновидящий ![]() |
Автор: MisterCleric 20.7.2010, 09:58 |
Привет. Так возьми свой CustomTable1 и пометь, что он Entity ну и @Id тоже. и все будет работать |
Автор: Nikola661 20.7.2010, 12:22 | ||||
Не понимаю тебя!!! Можно подробнее!!! Спасибо!!! Добавлено через 40 секунд
Блин, надо спробнуть, не догадался )))) ![]() |
Автор: AJetman 20.7.2010, 15:23 |
Если без вызова native query, то JPA может создавать нужные объекты, передавая поля в конструктор: List<SomeObject> list = em.createQuery("SELECT NEW SomeObject(e.param1, e.param2) FROM Entity e").getResultList(); Соответственно тип данных параметров конструктора должен совпадать с возвращаемых базой данных, о чем тоже есть в документации или есть сразу "не попадете", то в Exception увидите, что именно передавал в конструктор ваш JPA-провайдер. |
Автор: ki6opr 21.7.2010, 05:25 | ||||
тут это работает потому что в самом запросе указано что нужно создать объект и в него засунуть результаты. с native запросом нужно будет обязательно указывать какой класс должен быть создан в результате
и я более чем уверен что результирующий класс должен быть Entity |