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

Форум MySQL

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

 

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

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

тема: как организовать вывод новостей в обратном порядке
 
 автор: dimonich2004   (08.02.2008 в 16:45)   письмо автору
 
 

есть данные в таблице mysql
| id | id_n |
--------------
| 1 | qwe |
---------------
| 3 | rew |
--------------
| 7 | tre |
--------------
|31| g53 |
-------------
как сделать чтобы данные полученые из базы выводились в обратном порядке? по значению ID

   
 
 автор: Shiva   (08.02.2008 в 16:49)   письмо автору
 
   для: dimonich2004   (08.02.2008 в 16:45)
 

select * from TABLE_NAME order by id desc

   
 
 автор: dimonich2004   (08.02.2008 в 17:29)   письмо автору
 
   для: Shiva   (08.02.2008 в 16:49)
 

чем лучше воспользоваццо чтоб бралось по к примеру по пять значени
и потом можно было продолжить считываь далее


ну грубо говоря новостная лента выдаёт по пять значений (последних)
и можно было продолжить их выводить в обратном порядке с тогй новости на которой остановился запрос?
как организовать постраничный просмотр?! =))))))))))))))))))))))

   
 
 автор: Thrasher   (08.02.2008 в 17:51)   письмо автору
 
   для: dimonich2004   (08.02.2008 в 17:29)
 

На этом сайте есть скрипт для постраничной навигации.

   
 
 автор: dimonich2004   (08.02.2008 в 17:58)   письмо автору
 
   для: Thrasher   (08.02.2008 в 17:51)
 

Да видел...
тока не вепу как
ЗАМЕНИТЬ ЭТО ВЫРАЖЕНИЕ ИБО НА НЕГО ЖАЛУЕЦЦО БРАУЗЕР ПРИ ВЫПОЛНЕНИИ:

 <?
$total 
intval(($posts 1) / $num) + 1
    
?>

   
 
 автор: dimonich2004   (08.02.2008 в 19:48)   письмо автору
 
   для: dimonich2004   (08.02.2008 в 17:58)
 

HELP!

   
 
 автор: Unkind   (08.02.2008 в 19:58)   письмо автору
 
   для: dimonich2004   (08.02.2008 в 19:48)
 

Код выполняется не браузером, так что он не может "жаловаться" по этому поводу. Вы не сказали какие ошибки появляются.

   
 
 автор: dimonich2004   (08.02.2008 в 20:29)   письмо автору
 
   для: 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;  
    
?>

   
 
 автор: Unkind   (08.02.2008 в 20:34)   письмо автору
 
   для: dimonich2004   (08.02.2008 в 20:29)
 

$posts и/или $num array, resource, object или что-то еще в этом духе. И, соответсвенно, оператор "-" и/или "/" не может работать с такими данными.

   
 
 автор: dimonich2004   (08.02.2008 в 20:38)   письмо автору
 
   для: Unkind   (08.02.2008 в 20:34)
 

Будьте добры Подскажите как можно записать это выражение подругому!...

   
 
 автор: Unkind   (08.02.2008 в 20:45)   письмо автору
 
   для: dimonich2004   (08.02.2008 в 20:38)
 

Ваш нужно разобраться что такое $posts, что такое $num.

   
 
 автор: dimonich2004   (08.02.2008 в 21:04)   письмо автору
 
   для: 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))  
?> 

   
 
 автор: Unkind   (08.02.2008 в 21:08)   письмо автору
 
   для: dimonich2004   (08.02.2008 в 21:04)
 

> $posts = mysql_fetch_row($result);
mysql_fetch_row() возвращает массив. Тут можно сделать так:

<?php
// ...

$posts mysql_result($result0);

// ...
?>

   
 
 автор: dimonich2004   (09.02.2008 в 01:19)   письмо автору
 
   для: 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:20)   письмо автору
 
   для: dimonich2004   (09.02.2008 в 01:19)
 

неужели у авторов кода это работало!
http://www.softtime.ru/info/articlephp.php?id_article=33

   
 
 автор: Trianon   (10.02.2008 в 02:08)   письмо автору
 
   для: dimonich2004   (09.02.2008 в 01:20)
 

>неужели у авторов кода это работало!
>http://www.softtime.ru/info/articlephp.php?id_article=33

Конечно, нет.

Но поскольку ошибка, в сущности, на поверхности лежит,
и наталкиваются на нее посетители регулярно,
а статью админы исправлять не хотят не смотря на многочисленные замечания,
можно сделать вывод, что она оставлена намеренно, для отлова халявщиков. :)

   
 
 автор: Faraon   (10.02.2008 в 01:56)   письмо автору
 
   для: dimonich2004   (09.02.2008 в 01:19)
 

при mysql_fetch_row
$posts[0] это адекватно.

   
Rambler's Top100
вверх

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