YMHuK Опубликовано 10 Ноября 2006 Жалоба Поделиться Опубликовано 10 Ноября 2006 Что надо добавлять в запросе и после чего? Пример привидите плз. - К примеру нужно запросить топик, имеющий больше всех просмотров.- Или нужно запросить три топика, наиболее часто просматриваемых.Как сконструировать такие запросы? И для 1.3 и для 2.Х сойдет. Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
Destruction Опубликовано 10 Ноября 2006 Жалоба Поделиться Опубликовано 10 Ноября 2006 (изменено) SELECT * FROM `table` ORDER BY `column` DESC LIMIT 1 ; Изменено 10 Ноября 2006 пользователем Destruction Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
YMHuK Опубликовано 10 Ноября 2006 Автор Жалоба Поделиться Опубликовано 10 Ноября 2006 Спасибо! Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
brokerUA Опубликовано 18 Июня 2007 Жалоба Поделиться Опубликовано 18 Июня 2007 SELECT * FROM ibf_topics WHERE (forum_id='38')этот запрос возвращает набор строк где параметр forum_id = 38 SELECT MAX(tid) FROM ibf_topics WHERE (forum_id='38')а этот запрос возвращает одно поле с максимальным значением параметра tid и где forum_id = 38 а мне нужно чтоб возвращало всю строку а не одно поле... можно это както одним запросом сделать? з.ы. пытаюсь взять строку из SQL последней темы из заданного раздела Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
Sannis Опубликовано 18 Июня 2007 Жалоба Поделиться Опубликовано 18 Июня 2007 На 2 поста выше же написал Destruction SELECT * FROM `ibf_topics` WHERE forum_id=38 ORDER BY `start_date` DESC LIMIT 1 ; Если нужен ещё и сам пост енужно делать join. Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
brokerUA Опубликовано 18 Июня 2007 Жалоба Поделиться Опубликовано 18 Июня 2007 (изменено) сам пост я вытащил во втором запросеSELECT * FROM ibf_posts WHERE (topic_id='номер_из_запроса_выше')возможно не рационально использовать еще один запрос, но по другому не знаю... в sql я не силен 2 Sannis: Спасибо, все отлично пахает, если не трудно можно чтоб еще и пост вытягивало? Изменено 18 Июня 2007 пользователем brokerUA Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
h8)u Опубликовано 18 Июня 2007 Жалоба Поделиться Опубликовано 18 Июня 2007 Join syntax Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
Sannis Опубликовано 18 Июня 2007 Жалоба Поделиться Опубликовано 18 Июня 2007 Если одним запросом, то так(ошибся, можно без join'а):SELECT t.*, p.* FROM ibf_topics t, ibf_posts p WHERE p.topic_id=t.id AND forum_id=38 ORDER BY t.start_date DESC LIMIT 1 ;С join:SELECT t.*, p.* FROM ibf_topics t LEFT JOIN ibf_posts p ON (p.topic_id=t.id) WHERE forum_id=38 ORDER BY t.start_date DESC LIMIT 1 ;Правда есть разные мнения на счёт какой из вариантов лучше. А вообще лучше использовать функции ядра если всё это делается для форума: $this->ipsclass->DB->build_query( array( 'select' => 't.*, p.*', 'from' => array( 'topics' => 't', 'posts' => 'p' ), 'where' => 'p.topic_id=t.id AND forum_id=38', 'order' => 't.start_date', 'limit' => array( 1 ) ) ); $this->ipsclass->DB->exec_query();Загляните ко мне в подпись, там есть пример с join для вытягивания последних тем. Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
brokerUA Опубликовано 18 Июня 2007 Жалоба Поделиться Опубликовано 18 Июня 2007 воспользовался первым вариантом, отлично работает интересные мод "(SnS) SSI экпорт последних тем и сообщений" правда немного нетак как мне надо, но можно подкоректировать Еще раз Спасибо, выручил! Цитата Ссылка на комментарий Поделиться на других сайтах Прочее
Рекомендуемые сообщения
Присоединиться к обсуждению
Вы можете ответить сейчас, а зарегистрироваться позже. Если у вас уже есть аккаунт, войдите, чтобы ответить от своего имени.