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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> JPA выбрать все одним запросом 
:(
    Опции темы
endryha
Дата 8.2.2010, 16:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Всем привет.

Использую JPA и TopLink как ORM. 

Вопрос в том как выбрать записи из таблицы одним запросом. 

Первый вариант.

Код

em.find("SELECT c FROM Country c");


В данном случае запросов делается столько сколько записей в таблице.

Второй вариант через sql
Код

em.createNativeQuery("SELECT * FROM TBL_COUNTRY", Country.class);


В данном случае сначала делается запрос "SELECT * FROM TBL_COUNTRY" а потом еще столько же сколько записей в базе

В обеих предыдущих случаях мне возвращается уже типизированная коллекция List<Сountry>.

Третий вариант
Код

em.createNativeQuery("SELECT * FROM TBL_COUNTRY");


В этом случае делается один запрос в базу и достаются все записи но в таком случае мне возвращается коллекция векторов List<Vector>.

Вопрос в том как грамотно выбрать все записи из базы одним запросом при этом получив типизированную коллекцию обьектов List<Country>.

Заранее спасибо!

И еще забыл дописать, в первых двух случаях мы получаем сущности уже приаттаченые к персистенс контексту а в послденем нет.

Это сообщение отредактировал(а) endryha - 8.2.2010, 16:25
PM MAIL   Вверх
Joss
Дата 9.2.2010, 14:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Насколько я знаю, это сработает как нужно.
Код

Query q = em.createQuery("SELECT c FROM Country c");
List<Country> countries = q.getResultList() 


PM MAIL   Вверх
endryha
Дата 10.2.2010, 16:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Да ты прав, вся проблема в том что у меня Странна может иметь перента (другую страну регион) а в результате для каждой сущность еще выбираеться её перент. Поетому возможно и получаеться что еще делаеться запросов столько сколько записей достаеться....
PM MAIL   Вверх
Joss
Дата 11.2.2010, 16:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



По-моему, можно сделать вот так:
Код

em.createNativeQuery("SELECT c FROM Country c JOIN FETCH c.parent");

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

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

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


 




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


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

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