Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> JPA, использование простых классов,не persistent, JPA, использование простых классов 
:(
    Опции темы
Nikola661
Дата 20.7.2010, 09:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 82
Регистрация: 14.5.2007

Репутация: 1
Всего: 1



Чтобы получить данные мы делаем так:
Код

......
List<Table1> = query.getResultlist();
......


Но иногда нужно обеспечить не совсем простой вывод данных перед пользователем.
Можно ли использовать свой class?? Вот так:
Код

......
Query query = em.createNativeQuery("call store_proc(........)");
List<CustomTable1> = query.getResultlist();
......

Выдает ошибку: типа CustomTable1 не класс персистент ентити (чо за н..х не могу на англ печатать)

Тут хр. процедура store_proc(........) должна вернуть свой набор данных, который соответствует CustomTable1, который не persistent


PM MAIL   Вверх
ki6opr
Дата 20.7.2010, 09:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 67
Регистрация: 20.12.2006

Репутация: нет
Всего: нет



ну а просто в цикле пройти по результату и завернуть в обертку ?

PS просто если Вы нигде маппинг не настроили то вам вернется просто список каждый элемент которого массив с вашим результатом.
как бы ORM он не ясновидящий smile 

Это сообщение отредактировал(а) ki6opr - 20.7.2010, 09:57
PM MAIL ICQ   Вверх
MisterCleric
Дата 20.7.2010, 09:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1043
Регистрация: 16.2.2006
Где: Харьков, Украина

Репутация: 33
Всего: 38



Привет.
Так возьми свой CustomTable1 и пометь, что он Entity ну и @Id тоже. и все будет работать


--------------------
ПРИШЕЛ, УВИДЕЛ - ПЕРЕПИСАЛ...
PM MAIL ICQ   Вверх
Nikola661
Дата 20.7.2010, 12:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 82
Регистрация: 14.5.2007

Репутация: 1
Всего: 1



Цитата(ki6opr @ 20.7.2010,  09:55)
ну а просто в цикле пройти по результату и завернуть в обертку ?

PS просто если Вы нигде маппинг не настроили то вам вернется просто список каждый элемент которого массив с вашим результатом.
как бы ORM он не ясновидящий smile

Не понимаю тебя!!! Можно подробнее!!! Спасибо!!!

Добавлено через 40 секунд
Цитата(MisterCleric @ 20.7.2010,  09:58)
Привет.
Так возьми свой CustomTable1 и пометь, что он Entity ну и @Id тоже. и все будет работать

Блин, надо спробнуть, не догадался ))))  smile 
PM MAIL   Вверх
AJetman
Дата 20.7.2010, 15:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 74
Регистрация: 16.8.2009

Репутация: 2
Всего: 2



Если без вызова native query, то JPA может создавать нужные объекты, передавая поля в конструктор:

List<SomeObject> list = em.createQuery("SELECT NEW SomeObject(e.param1, e.param2) FROM Entity e").getResultList();

Соответственно тип данных параметров конструктора должен совпадать с возвращаемых базой данных, о чем тоже есть в документации или есть сразу "не попадете", то в Exception увидите, что именно передавал в конструктор ваш JPA-провайдер.
PM   Вверх
ki6opr
Дата 21.7.2010, 05:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 67
Регистрация: 20.12.2006

Репутация: нет
Всего: нет



Цитата(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-провайдер.

тут это работает потому что в самом запросе указано что нужно создать объект и в него засунуть результаты.
с native запросом нужно будет обязательно указывать какой класс должен быть создан в результате 

Код

public Query createNativeQuery(String sqlString, Class resultClass)
Create an instance of Query for executing a native SQL query.

Parameters:
sqlString - a native SQL query string
resultClass - the class of the resulting instance(s)
Returns:
the new query instance
Throws:
IllegalStateException - if this EntityManager has been closed.


и я более чем уверен что результирующий класс должен быть Entity
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java EE (J2EE) и Spring | Следующая тема »


 




[ Время генерации скрипта: 0.1023 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.