Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Многостраничный вывод на PHP, используя запрос к MySQL лишь один раз.

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Описание: Многостраничный вывод на PHP, используя запрос к MySQL лишь один раз.
bluser
Отправлено: 23 Апреля, 2017 - 09:16:15
Post Id


Новичок


Покинул форум
Сообщений всего: 3
Дата рег-ции: Апр. 2017  


Помог: 0 раз(а)




Есть большая MySQL база с множеством таблиц и в каждой таблице до 10 млн. записей ($bd).
Некоторые SQL($sql) запросы отрабатывается по несколько минут.
Получаем некий результат: $ result = mysqli_query ($bd, $sql).
В отдельном файле организуется вывод данных ($ result) в таблицу htmlв цикле:
while ($myrow= mysqli_fetch_assoc ($result)) {…}
Получается тысячи строк.
Задача: организовать вывод величины $ result с разбиением постранично, типа: 1 2 3 4 5 6 7 8 ... >
ОДНАКО: НЕЛЬЗЯ ИСПОЛЬЗОВАТЬ В ПОСТРАНИЧНОМ ВЫВОДЕ SQLЗАПРОСЫ К БАЗЕ ДАННЫХ, ТАК КАК КАЖДЫЙ ЗАПРОС И ЛЮБОЙ LIMITБУДЕТУТ ОТНИМАТЬ БОЛЬШОЕ ВРЕМЯ.
Иными словами: запрос SQL($sql) должен случаться 1 раз, а результат этого запроса ($ result) должен разбиваться и выводиться в многостраничном формате.
 
 Top
Мелкий Супермодератор
Отправлено: 23 Апреля, 2017 - 10:14:40
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




http://use-the-index-luke[dot]com/no-offset
Т.е. передавайте последний встреченный элемент данных с предыдущей страницы и читайте limit записей от него при той же сортировке.

bluser пишет:
Есть большая MySQL база

bluser пишет:
таблице до 10 млн. записей ($bd).

Это мелкая база.

bluser пишет:
запрос SQL($sql) должен случаться 1 раз, а результат этого запроса ($ result) должен разбиваться

В этом случае вам нужно вычитать весь результат запроса и сохранить его куда-то ещё в другое место. В подарок куча проблем с обновлением этого кеша, живущего отдельно от СУБД. Но, так тоже можно делать, да.


-----
PostgreSQL DBA
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Хранение данных, их вывод и обработка »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB