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

Форум MySQL

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

 

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

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

тема: Сборная сортировка
 
 автор: tuder   (14.06.2007 в 12:29)   письмо автору
 
 

Имеется таблица, пара колонок: Имя и Размер. С одним именем может быть несколько объектов разных размеров.

Делаю несколько выборок. Топ10 по количеству, по объёму, по среднему размеру.


SELECT name, sum(size) AS size FROM `table` GROUP BY name ORDER BY size DESC LIMIT 0 , 10


SELECT name, count(name) AS count FROM `table` GROUP BY name ORDER BY count DESC LIMIT 0 , 10


Вопрос, как сделать запрос с сортировкой по среднему размеру?


SELECT name, sum(size) / count(name) AS size FROM `table` GROUP BY name ORDER BY size DESC LIMIT 0 , 10
- не проходит

SELECT name, sum(size) AS size, count(name) AS count FROM `table` GROUP BY name ORDER BY ??? DESC LIMIT 0 , 10


Сделать выборку, после чего в Топ10 выводить size/count - получается - но не отсортировано.
И вообще, не понятно, можно ли в процессе устангвить такую сортировку. У меня только через три запроса получается.

Получится ли одним запросом? Если нет, то как лучше?

   
 
 автор: Trianon   (14.06.2007 в 13:03)   письмо автору
 
   для: tuder   (14.06.2007 в 12:29)
 

SELECT name, AVG(size) as avg GROUP BY name ORDER BY avg DESC LIMIT 10;

SELECT name, SUM(size)/COUNT(name) as avg GROUP BY name ORDER BY avg DESC LIMIT 10;

   
 
 автор: tuder   (14.06.2007 в 13:36)   письмо автору
 
   для: Trianon   (14.06.2007 в 13:03)
 

>SELECT name, SUM(size)/COUNT(name) as avg GROUP BY name ORDER BY avg DESC LIMIT 10;

Да, через этот вариант я прошёл. Но сбило с толку то, что в таблице оказались единичные наименования с большим весом, которые вылазили вверх. :-( А ожидались другие наименования.

Так проходит, но приходится ещё делать
where name>5
, что сюда не вписывается.


SELECT name, COUNT(name) as count, AVG(size) as avg GROUP BY name WHERE count>6 ORDER BY avg DESC LIMIT 10;
- не проходит.

   
 
 автор: Trianon   (14.06.2007 в 13:42)   письмо автору
 
   для: tuder   (14.06.2007 в 13:36)
 

>Так проходит, но приходится ещё делать where name>5 , что сюда не вписывается.

В условии такого не было.


>SELECT name, COUNT(name) as count, AVG(size) as avg GROUP BY name WHERE count>6 ORDER BY avg DESC LIMIT 10;
> - не проходит.

само собой. это уже совсем другой запрос. Вообще непонятно от какой задачи.

SQL-запросы это не вина и не салаты, которые можно комбинировать друг с другом, просто дописав один к другому.

   
 
 автор: tuder   (14.06.2007 в 13:45)   письмо автору
 
   для: Trianon   (14.06.2007 в 13:42)
 

Жалко. :-)

Но вроде как count посчитался, сгруппировавшись по имени, теперь можно проверить его на условие where и только в случае положительного ответа занести в итоговый результат.

Ну,это уже теория. На практике сделал несклькими запросами. Спасибо за подсказку.

   
 
 автор: Trianon   (14.06.2007 в 13:54)   письмо автору
 
   для: tuder   (14.06.2007 в 13:45)
 

Если Вы хотите фильтровать вывод после группировки, применяйте HAVING а не WHERE

   
 
 автор: tuder   (15.06.2007 в 07:49)   письмо автору
 
   для: Trianon   (14.06.2007 в 13:54)
 

Спасибо

   
Rambler's Top100
вверх

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