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

Форум MySQL

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

 

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

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

тема: ОТСОРТИРОВАТЬ данные по мах рейтингу
 
 автор: oppo   (26.08.2006 в 12:07)   письмо автору
 
 

НУЖНО ОТСОРТИРОВАТЬ данные по мах рейтингу .
Есть 2 поля кот. я выбираю
: g_rating (рейтинг от 1 до 5 )и g_votes (кол-во проголосовавших)
пробывал так

 . "\n ORDER BY     a.g_rating DESC,a.g_votes DESC  "

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

. "\n ORDER BY     a.g_rating/a.g_votes DESC  "

так работает - Вопрос : допустимо ли это

   
 
 автор: cheops   (26.08.2006 в 15:40)   письмо автору
 
   для: oppo   (26.08.2006 в 12:07)
 

Приведите запрос полностью

   
 
 автор: oppo   (26.08.2006 в 15:51)   письмо автору
 
   для: cheops   (26.08.2006 в 15:40)
 


 $sql = "SELECT a.id,a.catid,a.name,a.g_votes,a.g_rating,a.rev_size, cat.name as catname,cat.section "
   . "\n FROM #__gid AS a"
          . "\n INNER JOIN #__categories AS cat ON cat.id =a.catid AND cat.section='com_gid'"
             . "\n WHERE a.published='1' AND a.g_votes<>0 "
            . "\n AND (a.expires = '$nullDate' OR a.expires >= '$now' )"
       . "\n ORDER BY     a.g_rating/a.g_votes DESC  "
                . "\n LIMIT ".$params->get('limit_query');

   
 
 автор: oppo   (27.08.2006 в 01:43)   письмо автору
 
   для: oppo   (26.08.2006 в 15:51)
 

ну как можно так оставить с / .. все ж интересно ..- примера не нашел

   
 
 автор: cheops   (27.08.2006 в 11:06)   письмо автору
 
   для: oppo   (27.08.2006 в 01:43)
 

Да, можно использовать вычисляемые столбцы, обычно их вычисляют в списке столбцов, назначают псевдоним и затем псевдоним подставляют в ORDER BY.

   
 
 автор: oppo   (27.08.2006 в 12:11)   письмо автору
 
   для: cheops   (27.08.2006 в 11:06)
 

Спасибо ... попробывал с вашей подсказки

 $sql = "SELECT a.id,   ROUND(a.g_rating/a.g_votes,1) AS VOT      ,a.rev_size, cat.name as catname,cat.section "
  . "\n FROM #__gid AS a"
 . "\n INNER JOIN #__categories AS cat ON cat.id =a.catid "

 . "\n WHERE a.published='1' AND a.g_votes<>0 "

. "\n ORDER BY    VOT  DESC  "

ТОЖЕ РАБОТАЕТ .. интересно варианты равнозначны

   
 
 автор: cheops   (27.08.2006 в 12:34)   письмо автору
 
   для: oppo   (27.08.2006 в 12:11)
 

По сути дела да, только в последнем запросе - вычисляемый столбец помещается в результирующую таблицу.

   
Rambler's Top100
вверх

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