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

Форум MySQL

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

 

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

вид форума:
Линейный форум (новые сообщения вниз) Структурный форум

тема: Выбрать следующую запись...

Сообщения:  [1-10]   [11-17] 

 
 автор: Artemy   (03.04.2006 в 14:58)   письмо автору
 
   для: Trianon   (03.04.2006 в 14:06)
 

Ладно, спасибо за помощь!
Буду думать дальше, скорей всего прийдется воспользоваться 2-мя запросами.

   
 
 автор: Trianon   (03.04.2006 в 14:06)   письмо автору
 
   для: Artemy   (03.04.2006 в 13:55)
 

Совсем без вложенных обойтись не выйдет.
SELECT .. FROM(SELECT ...) as T всяко понадобится.

   
 
 автор: Artemy   (03.04.2006 в 13:55)   письмо автору
 
   для: Trianon   (03.04.2006 в 13:52)
 

Можно, но не желательно! Там и так за время загрузки страницы идет около 10 запросов.

   
 
 автор: Trianon   (03.04.2006 в 13:52)   письмо автору
 
   для: Artemy   (03.04.2006 в 13:50)
 

А два запроса подряд сделать тоже нельзя?

   
 
 автор: Artemy   (03.04.2006 в 13:50)   письмо автору
 
   для: Trianon   (03.04.2006 в 13:45)
 

Прощу прощения, забыл сказать. Вложенные запросы не работают.
Иначе я бы не спрашивал!

   
 
 автор: Trianon   (03.04.2006 в 13:45)   письмо автору
 
   для: Artemy   (03.04.2006 в 13:36)
 

Что-то такое:
SELECT * 
FROM tab 
WHERE id != $id AND abs(rating-$rating) = (
        SELECT min(abs(rating-$rating)) 
        FROM tab 
        WHERE NOT id = $id
 ) ORDER BY id


Можно то же самое на LEFT JOIN написать, и возможно даже обойтись без вложенных в условие WHERE SELECTов, но запрос будет выглядеть устрашающе.

   
 
 автор: Artemy   (03.04.2006 в 13:36)   письмо автору
 
   для: Trianon   (03.04.2006 в 13:31)
 

Ой, сорри, не обратил внимания! Нужно выбрать Олега и Юру!
Т.е. упорядочивать сначала по рейтингу, а потом по ИД.

   
 
 автор: Artemy   (03.04.2006 в 13:33)   письмо автору
 
   для: Loki   (03.04.2006 в 13:30)
 

Не рабатает!

Ошибка №1221
Wrong usage of UNION and ORDER BY

   
 
 автор: Trianon   (03.04.2006 в 13:31)   письмо автору
 
   для: Artemy   (03.04.2006 в 13:25)
 

Не смотря на то, что и у Олега и у Петра рейтинг отличается от Ваниного больше чем у Юры и Вовы? Т.е. порядок по рейтингу несущественен?

   
 
 автор: Loki   (03.04.2006 в 13:30)   письмо автору
 
   для: Artemy   (03.04.2006 в 13:25)
 

Лобовой вариант такой:

SELECT * FROM table WHERE active='1' AND rating<'5' ORDER BY rating DESC LIMIT 1
UNION 
SELECT * FROM table WHERE active='1' AND rating>'5' ORDER BY rating LIMIT 1

   

Сообщения:  [1-10]   [11-17] 

Форум разработан IT-студией SoftTime
Rambler's Top100
вверх

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