Постраничная навигация, проблема с выводом данных из бд.

Тема в разделе "Психологическая консультация", создана пользователем Mirage, 03.02.2010.

  1. Mirage
    Offline

    Mirage Недавно здесь

    Регистрация:
    21.01.2010
    Сообщения:
    16
    Симпатии:
    0
    Пол:
    Мужской
    Код (PHP):
    1. // Переменная хранит число сообщений выводимых на станице
    2. $num = 15;
    3. // Извлекаем из URL текущую страницу
    4. $page = $_GET['page'];
    5. // Определяем общее число сообщений в базе данных
    6. $result = mysql_query("SELECT COUNT(*) FROM plitka");
    7. $posts = mysql_result($result, 0, 0);
    8. // Находим общее число страниц
    9.  echo $posts."<br/>";
    10. echo $num."<br/>";
    11. $total = intval(($posts - 1) / $num) + 1;
    12. // Определяем начало сообщений для текущей страницы
    13. $page = intval($page);
    14. // Если значение $page меньше единицы или отрицательно
    15. // переходим на первую страницу
    16. // А если слишком большое, то переходим на последнюю
    17. if(empty($page) or $page < 0) $page = 1;
    18.   if($page > $total) $page = $total;
    19. // Вычисляем начиная к какого номера
    20. // следует выводить сообщения
    21. $start = $page * $num - $num;
    22. // Выбираем $num сообщений начиная с номера $start
    23. $result = mysql_query("SELECT * FROM plitka LIMIT $start, $num");
    24. // В цикле переносим результаты запроса в массив $postrow
    25. while ( $postrow[] = mysql_fetch_array($result))
    26. ////////////////
    27.   echo $start."<br>";
    28. for($i = 0; $i < $num; $i++)
    29. {
    30. echo       "<div id=catalog>"
    31. .$postrow[$i]['id_plitka']."&nbsp".$postrow[$i]['collection']."&nbsp".$postrow[$i]['name_plitka']."&nbsp<img id=plitka src=".$postrow[$i]['url_plitka'].">
    32.              </div>";
    33. }
    34. /////////////////
    35.   // Проверяем нужны ли стрелки назад
    36. if ($page != 1) $pervpage = '<a href= ./catalog10?page=1><<</a>
    37.                               <a href= ./catalog10?page='. ($page - 1) .'><</a> ';
    38. // Проверяем нужны ли стрелки вперед
    39. if ($page != $total) $nextpage = ' <a href= ./catalog10?page='. ($page + 1) .'>></a>
    40.                                   <a href= ./catalog10?page=' .$total. '>>></a>';
    41. // Находим две ближайшие станицы с обоих краев, если они есть
    42. if($page - 2 > 0) $page2left = ' <a href= ./catalog10?page='. ($page - 2) .'>'. ($page - 2) .'</a> | ';
    43. if($page - 1 > 0) $page1left = '<a href= ./catalog10?page='. ($page - 1) .'>'. ($page - 1) .'</a> | ';
    44. if($page + 2 <= $total) $page2right = ' | <a href= ./catalog10?page='. ($page + 2) .'>'. ($page + 2) .'</a>';
    45. if($page + 1 <= $total) $page1right = ' | <a href= ./catalog10?page='. ($page + 1) .'>'. ($page + 1) .'</a>';
    46. // Вывод меню
    47. echo $pervpage.$page2left.$page1left.'<b>'.$page.'</b>'.$page1right.$page2right.$nextpage;
    48. ?>


    Здравствуйте. Помогите, пожалуйста. Сейчас скрпит работает нормально. Выводит 15 значений на страницу. Но если закомментировать строку echo $start."<br>";, выдает 225 результатов на страницу. Пробовал выводить по 4 результата на страницу, выводит 16 результатов. Не пойму в чем косяк, не может же быть в это строке?! Заранее спасибо.
     
    Последнее редактирование: 03.02.2010
  2.  
  3. Mirage
    Offline

    Mirage Недавно здесь

    Регистрация:
    21.01.2010
    Сообщения:
    16
    Симпатии:
    0
    Пол:
    Мужской
    Код (PHP):
    1. while ( $postrow = @mysql_fetch_array($result))
    2. {
    3. echo "<div id='catalog'>
    4. <img class='plitka' src=".$postrow['url_plitka']."><br>".$postrow['collection']."<br>".$postrow['name_plitka']."<br>".$postrow['HxWxT']."<br>Цвет: ".$postrow['color']."<br>Пол: ".$postrow['cover']."<br>Тип плитки: ".$postrow['orient']."<br>Цена: ".$postrow['price']."<br>Произв.: ".$postrow['manufactured']."<br>Поверхность: ".$postrow['type_cover']."<br>Тип помещений: ".$postrow['room']."<br>Износ.: ".$postrow['PEI']."<br>Картинка: ".$postrow['picture'].
    5. "</div>";
    6. }

    Сделал так, всё работает.
     

Поделиться этой страницей

Загрузка...