Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум PHP

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Рекурсивная функция, разбивка на страницы
 
 автор: rised   (26.11.2006 в 20:44)   письмо автору
 
 

Здравствуйте!

Не могу решить логическую задачу:

В базе данных MySQL есть две таблицы:

categories (поля id, name, pid)
articles (id, name, pid)

Есть рекурсивная функция, которая делает проход по категории вызывая все содержащиеся в ней статьи и статьи в подкатегориях.

Нужно сделать разбивку на страницы.

Я просчитался и сделал с LIMIT $start,$pnumber

Где $start задается пользователем при нажатии на ссылку, а $pnumber - заданное количество статей на странице, например 10

Естественно у меня выводится по 10 статей каждой подкатегории - а в итоге получается огромная "простыня".

Как же мне сделать нормальную разбивку на страницы в рекурсивной функции, спасибо.

   
 
 автор: cheops   (27.11.2006 в 13:51)   письмо автору
 
   для: rised   (26.11.2006 в 20:44)
 

Вместо непосредственного вывода в браузер, рекурсивную функцию обычно заставляют поместить блоки в массив, постраничную навигацию для которого затем организуют при помощи скрипта http://www.softtime.ru/scripts/pager.php.

   
 
 автор: Trianon   (27.11.2006 в 15:00)   письмо автору
 
   для: cheops   (27.11.2006 в 13:51)
 

подход хорош для случая, когда на странице должно быть определенное число символов(или строк). Если требуется выдержать определенное число статей на странице, имеет смысл сложить в массив не сами статьи, а их первичные ключи - в порядке вывода. И применить

SELECT ... WHERE id IN ($list) ORDER BY FIND_IN_SET (id, '$list') LIMIT $num, $start

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования