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

Форум PHP

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

 

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

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

тема: Пишу форум. Проблема с поднятием тем,
 
 автор: Oberon   (05.10.2007 в 08:59)   письмо автору
 
 

При написании форума столкнулся с проблемой сортировки тем в разделе.. Дело в том, что мне нужно что бы темы сортировались по последнему сообщению в теме. То есть, зашел в нижнюю тему, добавил сообщение, и тема оказалась в самом верху раздела.. Уже четвертый день мучаюсь, не получается у меня организовать это.. Кто то сталкивался с такой проблемой? Поделитесь опытом,.. Форум на мускуле,..

   
 
 автор: sim5   (05.10.2007 в 09:15)   письмо автору
 
   для: Oberon   (05.10.2007 в 08:59)
 

При запросе сообщений из базы выберите порядок сортировки DESC.

   
 
 автор: Oberon   (05.10.2007 в 09:21)   письмо автору
 
   для: sim5   (05.10.2007 в 09:15)
 

DESC просто отсортирует темы в убывающем порядке. У меня ситуация немного сложнее.. Нужно отсортировать темы именно по дате последнего сообщения, оставленного в теме. Сложность в том, что Темы и Сообщения находятся в разных таблицах.

   
 
 автор: Valick   (05.10.2007 в 09:17)   письмо автору
 
   для: Oberon   (05.10.2007 в 08:59)
 

Понятия не имею как пишутся форумы. Но я бы сделал так.
в таблице темы рядом с айди ябы сделал поле в которое писал время добавления последнего поста в теме. И сортируйте наздоровье как угодно.

   
 
 автор: Oberon   (05.10.2007 в 09:23)   письмо автору
 
   для: Valick   (05.10.2007 в 09:17)
 

Так, спасибо. Почему то сразу я об этом не подумал,

   
 
 автор: RV   (05.10.2007 в 09:47)   письмо автору
 
   для: Oberon   (05.10.2007 в 09:23)
 

можно сделать запрос немного сложнее и не добавлять новых полей. тем более эти поля будут избыточными (дата последнего сообщения итак есть в таблице с сообщениями, зачем ее еще в таблицу с темами добавлять).

   
 
 автор: Oberon   (05.10.2007 в 10:07)   письмо автору
 
   для: RV   (05.10.2007 в 09:47)
 

Именно такой запрос я и хотел сделать. Смекалки не хватает... А вообще, хотелось бы конечно обойтись одним запросом, нежели лишнее поле создавать,

   
 
 автор: Valick   (05.10.2007 в 10:25)   письмо автору
 
   для: Oberon   (05.10.2007 в 10:07)
 

Я просто думал, что выборка в этом случае(при добавлении нового поля) была бы быстрее, может я и не прав.

   
 
 автор: RV   (05.10.2007 в 11:22)   письмо автору
 
   для: Valick   (05.10.2007 в 10:25)
 

Запрос зависет от того, какой у вас уже имеется, от таблиц и имен столбцов

   
 
 автор: Oberon   (05.10.2007 в 11:55)   письмо автору
 
   для: RV   (05.10.2007 в 11:22)
 

таблицы выглядят примерно следующим образом:


CREATE TABLE `forum_msg` (
  `id` int(11) NOT NULL auto_increment,
  `msg` text NOT NULL,
  `date` text NOT NULL,
  `time` text NOT NULL,
  `theme_id` int(11)          //////////////////   `theme_id` (`forum_msg`)  == `id` (`forum_theme`)

CREATE TABLE `forum_theme` (
  `id` int(11) NOT NULL auto_increment,
  `name` text NOT NULL,
  `date` text NOT NULL,
  `time` text NOT NULL,
  `part_id` int(11)            ///////////////// `part_id` (`forum_theme`) == `id` (`forum_part`)


текущий запрос пока что просто сортирует темы по убыванию, выглядит примерно так:
mysql_query("select * from `forum_theme` where `part_id` = '$id' ORDER BY `id` DESC")

   
 
 автор: Faraon   (05.10.2007 в 12:29)   письмо автору
 
   для: Oberon   (05.10.2007 в 11:55)
 

Ничего у вас не получится, поле date должно быть календарного типа (DATE) а не текстового

   
Rambler's Top100
вверх

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