|
|
|
| есть данные в таблице mysql
| id | id_n |
--------------
| 1 | qwe |
---------------
| 3 | rew |
--------------
| 7 | tre |
--------------
|31| g53 |
-------------
как сделать чтобы данные полученые из базы выводились в обратном порядке? по значению ID | |
|
|
|
|
|
|
|
для: dimonich2004
(08.02.2008 в 16:45)
| |
select * from TABLE_NAME order by id desc
|
| |
|
|
|
|
|
|
|
для: Shiva
(08.02.2008 в 16:49)
| | чем лучше воспользоваццо чтоб бралось по к примеру по пять значени
и потом можно было продолжить считываь далее
ну грубо говоря новостная лента выдаёт по пять значений (последних)
и можно было продолжить их выводить в обратном порядке с тогй новости на которой остановился запрос?
как организовать постраничный просмотр?! =)))))))))))))))))))))) | |
|
|
|
|
|
|
|
для: dimonich2004
(08.02.2008 в 17:29)
| | На этом сайте есть скрипт для постраничной навигации. | |
|
|
|
|
|
|
|
для: Thrasher
(08.02.2008 в 17:51)
| | Да видел...
тока не вепу как
ЗАМЕНИТЬ ЭТО ВЫРАЖЕНИЕ ИБО НА НЕГО ЖАЛУЕЦЦО БРАУЗЕР ПРИ ВЫПОЛНЕНИИ:
<?
$total = intval(($posts - 1) / $num) + 1;
?>
|
| |
|
|
|
|
|
|
|
для: dimonich2004
(08.02.2008 в 17:58)
| | HELP! | |
|
|
|
|
|
|
|
для: dimonich2004
(08.02.2008 в 19:48)
| | Код выполняется не браузером, так что он не может "жаловаться" по этому поводу. Вы не сказали какие ошибки появляются. | |
|
|
|
|
|
|
|
для: Unkind
(08.02.2008 в 19:58)
| | Fatal error: Unsupported operand types in C:\xampplite\htdocs\www\news.php on line 46
<?
$total = intval(($posts - 1) / $num) + 1;
?>
|
| |
|
|
|
|
|
|
|
для: dimonich2004
(08.02.2008 в 20:29)
| | $posts и/или $num array, resource, object или что-то еще в этом духе. И, соответсвенно, оператор "-" и/или "/" не может работать с такими данными. | |
|
|
|
|
|
|
|
для: Unkind
(08.02.2008 в 20:34)
| | Будьте добры Подскажите как можно записать это выражение подругому!... | |
|
|
|
|
|
|
|
для: dimonich2004
(08.02.2008 в 20:38)
| | Ваш нужно разобраться что такое $posts, что такое $num. | |
|
|
|
|
|
|
|
для: Unkind
(08.02.2008 в 20:45)
| |
<?php
// Устанавливаем соединение с базой данных
include "config.php";
// Переменная хранит число сообщений выводимых на станице
$num = 25;
// Извлекаем из URL текущую страницу
$page = $_GET['page'];
// Определяем общее число сообщений в базе данных
$result = mysql_query("SELECT COUNT(*) FROM post");
$posts = mysql_fetch_row($result);
// Находим общее число страниц
$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 post LIMIT $start, $num");
// В цикле переносим результаты запроса в массив $postrow
while ( $postrow[] = mysql_fetch_array($result))
?>
|
| |
|
|
|
|
|
|
|
для: dimonich2004
(08.02.2008 в 21:04)
| | > $posts = mysql_fetch_row($result);
mysql_fetch_row() возвращает массив. Тут можно сделать так:
<?php
// ...
$posts = mysql_result($result, 0);
// ...
?>
|
| |
|
|
|
|
|
|
|
для: dimonich2004
(08.02.2008 в 21:04)
| | Блин постят исходники с ошибками!
или Это под старые версии PHP
Подправил строки и всё запахало!
<?
$total = intval(($posts - 1) / $num) + 1;
// Была пустая переменная POST + при делении если получалось не целое число то выдавало ошибку!
?>
|
на
<?
$total = intval(($posts[0] - 1) % $num) + 1;
?>
|
| |
|
|
|
|
|
|
|
для: dimonich2004
(09.02.2008 в 01:19)
| | неужели у авторов кода это работало!
http://www.softtime.ru/info/articlephp.php?id_article=33 | |
|
|
|
|
|
|
|
для: dimonich2004
(09.02.2008 в 01:20)
| | >неужели у авторов кода это работало!
>http://www.softtime.ru/info/articlephp.php?id_article=33
Конечно, нет.
Но поскольку ошибка, в сущности, на поверхности лежит,
и наталкиваются на нее посетители регулярно,
а статью админы исправлять не хотят не смотря на многочисленные замечания,
можно сделать вывод, что она оставлена намеренно, для отлова халявщиков. :) | |
|
|
|
|
|
|
|
для: dimonich2004
(09.02.2008 в 01:19)
| | при mysql_fetch_row
$posts[0] это адекватно. | |
|
|
|