Другие языки программирования и технологии

PHP. Вывод из базы с конца по id.

Нужно чтоб статьи выводились с последней по первую а не наоборот. Сортировка по id. К тому же я уже сделала постраничную навигацию потому код выглядит вот так: <textarea> .... <?php // Переменная хранит число сообщений выводимых на станице $num = 4; // Извлекаем из URL текущую страницу @$page = $_GET['page']; // Определяем общее число сообщений в базе данных $result00 = mysql_query("SELECT COUNT(*) FROM advent"); $temp = mysql_fetch_array($result00); $posts = $temp[0]; // Находим общее число страниц $total = (($posts - 1) / $num) + 1; $total = intval($total); // Определяем начало сообщений для текущей страницы $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 id, title, date, description, author FROM advent ORDER BY id LIMIT $start, $num", $db); $myrow = mysql_fetch_array($result); do { printf (" %s Дата добавления: %s Автор: %s %s ", $myrow ['id'], $myrow ['title'], $myrow ['date'], $myrow ['author'], $myrow ['description'] ); } while ( $myrow = mysql_fetch_array($result)); // Проверяем нужны ли стрелки назад if ($page != 1) $pervpage = 'Первая | Предыдущая | '; // Проверяем нужны ли стрелки вперед if ($page != $total) $nextpage = ' | Следующая | Последняя'; // Находим две ближайшие станицы с обоих краев, если они есть if($page - 5 > 0) $page5left = ' '. ($page - 5) .' | '; if($page - 4 > 0) $page4left = ' '. ($page - 4) .' | '; if($page - 3 > 0) $page3left = ' '. ($page - 3) .' | '; if($page - 2 > 0) $page2left = ' '. ($page - 2) .' | '; if($page - 1 > 0) $page1left = ''. ($page - 1) .' | '; if($page + 5 <= $total) $page5right = ' | '. ($page + 5) .''; if($page + 4 <= $total) $page4right = ' | '. ($page + 4) .''; if($page + 3 <= $total) $page3right = ' | '. ($page + 3) .''; if($page + 2 <= $total) $page2right = ' | '. ($page + 2) .''; if($page + 1 <= $total) $page1right = ' | '. ($page + 1) .''; // Вывод меню если страниц больше одной if ($total > 1) { Error_Reporting(E_ALL & ~E_NOTICE); echo ""; echo $pervpage.$page5left.$page4left.$page3left.$page2left.$page1left.''.$page.''.$page1right.$page2right.$page3right.$page4right.$page5right.$nextpage; echo ""; } ?> ...</textarea> Буду премного благодарна. Спасибо заранее.
Измени в SQL запросе сортировку

то есть не просто ORDER BY id

а конкретно ORDER BY id ASC
или ORDER BY id DESC

разница между ASC и DESC

ASC сортирует по возрастанию (1,2,3,4,5)

DESC сортирует по убыванию (5,4,3,2,1)
ДБ
Дмитрий Белоруков
1 724
Лучший ответ
эм. . стучи в агент скажу как и дам свой клас для постраничной навигации!
Ермек Аскаров
Ермек Аскаров
41 003
так в скульзапросе и скажи
SELECT id, title, date, description, author FROM advent ORDER BY id _DESC_ LIMIT $start, $num
десцендинг или асцендинг
просто прочитай про конструкцию селект токен ордер бай поле асц, десц, лимит
либо перепиши
ORDER BY поле [ASC,DESC] WHERE id>$start and id<$end

и вот это попробуйте цикл+массив? хотя.. . и так работает и ладно:))))))) 0_0
f($page - 5 > 0) $page5left = ' [ссылка появится после проверки модератором] | ';
if($page - 4 > 0) $page4left = ' [ссылка появится после проверки модератором] | ';
if($page - 3 > 0) $page3left = ' [ссылка появится после проверки модератором] | ';
if($page - 2 > 0) $page2left = ' [ссылка появится после проверки модератором] | ';
if($page - 1 > 0) $page1left = '[ссылка появится после проверки модератором] | ';

if($page + 5 <= $total) $page5right = ' | [ссылка появится после проверки модератором] ';
if($page + 4 <= $total) $page4right = ' | [ссылка появится после проверки модератором] ';
if($page + 3 <= $total) $page3right = ' | [ссылка появится после проверки модератором] ';
if($page + 2 <= $total) $page2right = ' | [ссылка появится после проверки модератором] ';
if($page + 1 <= $total) $page1right = ' | [ссылка появится после проверки модератором] ';
Арсен Катханов
Арсен Катханов
17 417
пробуй так: найди самій большой ид и потом выведи и потом по -1 если нотнулл выводи и вот тебе сортировка