Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Вывести данные с конца БД

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
Ermite
Отправлено: 06 Августа, 2016 - 17:29:26
Post Id


Новичок


Покинул форум
Сообщений всего: 41
Дата рег-ции: Февр. 2016  


Помог: 0 раз(а)




Сделал лог действий пользователя, типа "Зашел на сайт", "Написал сообщение" и т.д.
Вывожу пользователю вот таким образом:

PHP:
скопировать код в буфер обмена
  1. $log_out = $mysqli->query("SELECT * FROM `log` WHERE `id` = '".$id."'"); // $id - айди пользователя
  2. while ($log_search = mysqli_fetch_assoc($log_out)) {
  3. echo $log_search['action'];    
  4. }


А теперь вопрос: как сделать вывод с конца БД? Чтобы вначале у пользователя отображались последние действия, а не первые?
 
 Top
Fart
Отправлено: 06 Августа, 2016 - 20:16:46
Post Id



Посетитель


Покинул форум
Сообщений всего: 324
Дата рег-ции: Июль 2016  


Помог: 10 раз(а)




думаю, ты как то привязывал действия пользователя к определенному отрезку времени или же к конкретному `time` то:

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM `log` WHERE `id` = '".$id."' ORDER BY `time` DESC


запрос сортирует по возрастанию. в конце запроса можно указать LIMIT и то количество строк, которые нужны
 
 Top
Ermite
Отправлено: 06 Августа, 2016 - 20:46:08
Post Id


Новичок


Покинул форум
Сообщений всего: 41
Дата рег-ции: Февр. 2016  


Помог: 0 раз(а)




Fart пишет:
думаю, ты как то привязывал действия пользователя к определенному отрезку времени или же к конкретному `time` то:

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM `log` WHERE `id` = '".$id."' ORDER BY `time` DESC


запрос сортирует по возрастанию. в конце запроса можно указать LIMIT и то количество строк, которые нужны

Спасибо больше, помогло Улыбка
 
 Top
vintag
Отправлено: 06 Августа, 2016 - 20:46:27
Post Id



Новичок


Покинул форум
Сообщений всего: 35
Дата рег-ции: Нояб. 2015  


Помог: 0 раз(а)




Fart пишет:
думаю, ты как то привязывал действия пользователя к определенному отрезку времени или же к конкретному `time`

Достаточно примаари кей использовать инт нот нулл автоинкремент
 
 Top
Fart
Отправлено: 06 Августа, 2016 - 22:00:11
Post Id



Посетитель


Покинул форум
Сообщений всего: 324
Дата рег-ции: Июль 2016  


Помог: 10 раз(а)




vintag пишет:
Достаточно примари кей использовать инт нот нулл автоинкремент


можно и так, однако, с A_I не стоит играть и особо доверять ему. ИМХО A_I желательно для очень простых таблиц с "одним" ключом.

иногда возникают "баги" если A_I в 1 таблице и разных столбцах... вот тогда поиск будет отображать иногда не то, что нужно. да и к тому же, строчка кода не на столько громоздка.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB