$num = 10; // Извлекаем из URL текущую страницу $page = $_GET['page']; // Определяем общее число сообщений в базе данных $result = mysql_query("SELECT COUNT(id) FROM chat"); $posts = mysql_result($result, 0); // Находим общее число страниц $total = intval(($posts - 1) / $num) + 1; // Определяем начало сообщений для текущей страницы $page = intval($page); // Если значение $page меньше единицы или отрицательно // переходим на первую страницу // А если слишком большое, то переходим на последнюю if(empty($page) or $page < 0) $page = 1; if($page > $total) $page = $total; // Вычисляем начиная к какого номера // следует выводить сообщения $start = $page * $num - $num; // Выбираем $num сообщений начиная с номера $start //$result = mysql_query("SELECT * FROM chat LIMIT $start, $num"); // В цикле переносим результаты запроса в массив $postrow //while ( $postrow[] = mysql_fetch_array($result)) if ($page != 1) $pervpage = '<< < '; // Проверяем нужны ли стрелки вперед if ($page != $total) $nextpage = ' > >>'; // Находим две ближайшие станицы с обоих краев, если они есть if($page - 2 > 0) $page2left = ' '. ($page - 2) .' | '; if($page - 1 > 0) $page1left = ''. ($page - 1) .' | '; if($page + 2 <= $total) $page2right = ' | '. ($page + 2) .''; if($page + 1 <= $total) $page1right = ' | '. ($page + 1) .''; $test = mysql_query("SELECT * FROM chat LIMIT $start, $num"); while($row = mysql_fetch_assoc($test)) { echo ''; } // Вывод меню echo "";