|
1 / 1 / 0
Регистрация: 17.09.2014
Сообщений: 94
|
||||||||||||||||
Primefaces + Hibenate (порционная загрузка списка)23.03.2016, 16:59. Показов 4045. Ответов 54
Метки нет (Все метки)
Всем доброго времени суток.
Есть проект, база данных которых постоянно расширяется и время загрузки некоторых страниц, мягко говоря, оставляет желать лучшего. Проект реализован на primefaces + hibernate + postgresql. На данных момент прежде чем открыть страницу, где находится какой-то список, загружается список скопом и отображается на xhtml группами по 20. Прошу помощи подсказать как лучше реализовать порционную загрузку, используя данные технологии в моем случае. Вот моя визуалка
0
|
||||||||||||||||
| 23.03.2016, 16:59 | |
|
Ответы с готовыми решениями:
54
Порционная загрузка с AsyncTask и бесконечный скролл Spring + hibenate, REST Порционная выборка записей из бд |
|
149 / 162 / 48
Регистрация: 19.10.2012
Сообщений: 530
|
||||
| 23.03.2016, 17:31 | ||||
|
Если
0
|
||||
|
1 / 1 / 0
Регистрация: 17.09.2014
Сообщений: 94
|
|
| 23.03.2016, 17:48 [ТС] | |
|
Любопытный,
1. Насчет оптимальности я предложу своим пересмотреть, спасибо. 2. Интересный вариант, правда насколько проблематично будет его внедрить в уже сущестувющий код? Получается в setFirstResult(n) n - это типа номер страницы с результатами? 3. Я думаю да, проект уже больше 3 лет разрабатывается, а мне бы просто доработать порционную загрузку больших списков.
0
|
|
|
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
|
||
| 23.03.2016, 18:04 | ||
|
Добавлено через 2 минуты Вообще по гуглу primefaces pagination довольно много результатов. Вот например http://www.primefaces.org/show... lazy.xhtml
0
|
||
|
1 / 1 / 0
Регистрация: 17.09.2014
Сообщений: 94
|
||||||
| 29.03.2016, 09:38 [ТС] | ||||||
|
Любопытный, KEKCoGEN, Начал продвигаться в моем направлении с помощью ваших подсказок, но запнулся на одном моменте. У меня уже вроде было все готово для использования ленивой выгрузки, но она все не работала. А потом я интереса ради к своему старому запросу к бд просто добавил
0
|
||||||
|
149 / 162 / 48
Регистрация: 19.10.2012
Сообщений: 530
|
|
| 29.03.2016, 09:55 | |
|
Добавьте код, и лог с запросом, который отправляет хибернейт.
0
|
|
|
1 / 1 / 0
Регистрация: 17.09.2014
Сообщений: 94
|
|||||||||||
| 29.03.2016, 10:34 [ТС] | |||||||||||
|
Любопытный, Это лог
А вот код хелпера
0
|
|||||||||||
|
149 / 162 / 48
Регистрация: 19.10.2012
Сообщений: 530
|
|
| 29.03.2016, 10:44 | |
|
0
|
|
|
1 / 1 / 0
Регистрация: 17.09.2014
Сообщений: 94
|
|
| 29.03.2016, 11:39 [ТС] | |
|
Любопытный, Как я понял это из-за того что в запросе я использую "join fetch". То есть как вариант загружать мои объекты без "join fetch", а потом просто создавать новый список и по отдельности выгружать каждый объект со связями по айди, верно?
0
|
|
|
149 / 162 / 48
Регистрация: 19.10.2012
Сообщений: 530
|
|
| 29.03.2016, 12:16 | |
|
TAHKICT, Вам виднее, вы ведь знаете как у вас построена структура отношений, и какие данные вам нужно получить.
Я бы на Вашем месте таки включил логирование sql-запросов и генерацию статистики, и внимательно просмотрел как эти запросы проходят, потом просмотрел план выполнения запросов, может есть узкие места и Вы делаете дурную работу.
0
|
|
|
1 / 1 / 0
Регистрация: 17.09.2014
Сообщений: 94
|
|
| 04.04.2016, 20:01 [ТС] | |
|
Любопытный, KEKCoGEN, Извините что беспокою Вас. А как мне быть с фильтрами? Допустим саму порционную загрузку я сделаю хитромудрыми запросами к базе. Просто на xhtml у меня у меня располагается таблица, данные в которой заполняются из различных связанных объектов. Можно как-то реализовать фильтрацию по полям тех связанных объектов (что-бы искать по всей базе данных, а не только по тем 20 строкам, которые отображаются).
Очень надеюсь на вашу помощь.
0
|
|
|
149 / 162 / 48
Регистрация: 19.10.2012
Сообщений: 530
|
|
| 04.04.2016, 20:14 | |
|
TAHKICT, добавить условие фильтрации в спецификацию SQL запроса.
0
|
|
|
1 / 1 / 0
Регистрация: 17.09.2014
Сообщений: 94
|
|
| 04.04.2016, 22:10 [ТС] | |
|
Любопытный, а какой массив данных мы будем фильтровать? Просто, как я понял, у меня будет следующую логика загрузки данных
1. Идет запрос к бд по выборке данных с использованием "setMaxResults(n).setFirstResult(n)" 2. Затем по вытянутому списку я вытягиваю все необходимые зависимости. 3. Формирую список обёрток и отправляю на xhtml Я так понимаю мне придется отказаться от оберток? И какова логика фильтра будет? Извините за глупые вопросы может быть. Сейчас у меня выгружается весь список объектов со всеми необходимыми зависимостями, создается список оберток и передаем на отображение. А потом классическим инструментом primefaces производится фильтрация.
0
|
|
|
149 / 162 / 48
Регистрация: 19.10.2012
Сообщений: 530
|
|
| 05.04.2016, 08:04 | |
|
TAHKICT, если Вы выгружаете данные блоками, используя пагинацию, то для фильтрации/сортировки нужно делать новый запрос в базу, с соответствующими операторами и условиями.
0
|
|
|
1 / 1 / 0
Регистрация: 17.09.2014
Сообщений: 94
|
||||||
| 07.04.2016, 14:13 [ТС] | ||||||
|
KEKCoGEN, Любопытный, Привет еще раз. Хочу вот побороть просто порционную загрузку. Написал хэлпер, который может работать setMaxResults(n).setFirstResult(n) и проверил его работоспособность. Следуя различным способам реализации lazymodel сделал свою.
0
|
||||||
|
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
|
||
| 07.04.2016, 14:20 | ||
|
Так же включите отображение запросов к БД в хибернейте и смотрите какой запрос выходит
0
|
||
|
149 / 162 / 48
Регистрация: 19.10.2012
Сообщений: 530
|
||
| 07.04.2016, 14:23 | ||
|
0
|
||
|
1 / 1 / 0
Регистрация: 17.09.2014
Сообщений: 94
|
||||||
| 07.04.2016, 14:36 [ТС] | ||||||
|
KEKCoGEN, Любопытный,
0
|
||||||
|
2399 / 2224 / 565
Регистрация: 28.12.2010
Сообщений: 8,672
|
||
| 07.04.2016, 14:40 | ||
|
Ну и остальной код ужасен
0
|
||
|
149 / 162 / 48
Регистрация: 19.10.2012
Сообщений: 530
|
|
| 07.04.2016, 14:56 | |
|
Вы получаете полный список записей из Product, а потом по каждому из итемов записи делаете вон тот монструозный запрос, где же тут лейзи? Оптимизируйте запросы. Еще раз говорю, посмотрите как этот запрос выглядит в конечном варианте, что именно запрашивается из бд, потом просмотрите профиль запроса и увидите почему оно так долго выполняется и что можно изменить.
0
|
|
| 07.04.2016, 14:56 | |
|
Помогаю со студенческими работами здесь
20
primefaces Загрузка списка из БД JSF primefaces Сортировка, Primefaces Загрузка двухуровнего списка Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога
Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
|
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
|
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога
В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
|
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
|
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога
Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
|
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования.
Часть библиотеки BedvitCOM
Использованы. . .
|
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога
SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
|