Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / MySQL [игнор отключен] [закрыт для гостей] / COUNT и GROUP BY, как в вывод включить пустые значения (нули). / 4 сообщений из 4, страница 1 из 1
19.11.2016, 13:08
    #39350269
st22
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
COUNT и GROUP BY, как в вывод включить пустые значения (нули).
SELECT COUNT(parent_id) FROM dl_category WHERE parent_id IN (98,78,79,81,9,58,59,29,30,24,53,51,28,27,18) GROUP BY parent_id;

Выводит: 15 3 12 2

А остальное? А нули...?

Т.е. как изменить запрос, чтобы вывод был еще и с нулями?
Подскажите пожалуйста.
...
Рейтинг: 0 / 0
19.11.2016, 13:40
    #39350279
st22
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
COUNT и GROUP BY, как в вывод включить пустые значения (нули).
Что-то я напутал, пытаюсь разобраться...
...
Рейтинг: 0 / 0
19.11.2016, 14:37
    #39350291
Melkij
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
COUNT и GROUP BY, как в вывод включить пустые значения (нули).
Группировка не вернёт ничего для отсутствующих строк. Нет строк после фильтра - откуда бы им взяться в результате группировки?
Чтобы запрос вернул заданное количество строк с count=0, если таких строк нет вообще - надо прикручивать опорную таблицу сбоку.
Глупый mysql не умеет никаких values, unnest и вообще ничего подходящего для этой задачи. Поэтому сделайте эту обработку лучше на приложении. mysql объяснять несколько многословно, что от него хотят получить. Но можно и объяснить, например:

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
select parent_id, coalesce(cnt, 0) from (
    select 98 as parent_id
    union all 
    select 78
    union all /* и т.д. остальные значения*/
) base_ids left join (
    select parent_id, count(0) as cnt from dl_category WHERE parent_id IN (98,78,79,81,9,58,59,29,30,24,53,51,28,27,18) GROUP BY parent_id
) count_ids using(parent_id)


В простых случаях можно напрямую переджойнить селект из толпы union all к табличке и посчитать count. Тогда хоть в where дублировать условие не надо.
...
Рейтинг: 0 / 0
19.11.2016, 18:12
    #39350323
st22
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
COUNT и GROUP BY, как в вывод включить пустые значения (нули).
Спасибо.
Решилось с помощью php.
...
Рейтинг: 0 / 0
Форумы / MySQL [игнор отключен] [закрыт для гостей] / COUNT и GROUP BY, как в вывод включить пустые значения (нули). / 4 сообщений из 4, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]