|
|
|
|
|
для: Trianon
(14.06.2007 в 13:54)
| | Спасибо | |
|
|
|
|
|
|
|
для: tuder
(14.06.2007 в 13:45)
| | Если Вы хотите фильтровать вывод после группировки, применяйте HAVING а не WHERE | |
|
|
|
|
|
|
|
для: Trianon
(14.06.2007 в 13:42)
| | Жалко. :-)
Но вроде как count посчитался, сгруппировавшись по имени, теперь можно проверить его на условие where и только в случае положительного ответа занести в итоговый результат.
Ну,это уже теория. На практике сделал несклькими запросами. Спасибо за подсказку. | |
|
|
|
|
|
|
|
для: 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-запросы это не вина и не салаты, которые можно комбинировать друг с другом, просто дописав один к другому. | |
|
|
|
|
|
|
|
для: Trianon
(14.06.2007 в 13:03)
| | >SELECT name, SUM(size)/COUNT(name) as avg GROUP BY name ORDER BY avg DESC LIMIT 10;
Да, через этот вариант я прошёл. Но сбило с толку то, что в таблице оказались единичные наименования с большим весом, которые вылазили вверх. :-( А ожидались другие наименования.
Так проходит, но приходится ещё делать , что сюда не вписывается.
SELECT name, COUNT(name) as count, AVG(size) as avg GROUP BY name WHERE count>6 ORDER BY avg DESC LIMIT 10;
| - не проходит. | |
|
|
|
|
|
|
|
для: 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; | |
|
|
|
|
|
|
| Имеется таблица, пара колонок: Имя и Размер. С одним именем может быть несколько объектов разных размеров.
Делаю несколько выборок. Топ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 - получается - но не отсортировано.
И вообще, не понятно, можно ли в процессе устангвить такую сортировку. У меня только через три запроса получается.
Получится ли одним запросом? Если нет, то как лучше? | |
|
|
|
|