Подзапрос SQL, получить количество идентификаторов на основе результатов подзапроса

Я написал такой подзапрос:

Select ID, count(*) as cn from xyz group by 1

Результаты в выводе-

Я БЫСп
А3
Б45

Теперь я делаю этот запрос -

SELECT CASE
         WHEN temp.cn > 10 THEN Count(DISTINCT id)
       END AS cn_10,
       CASE
         WHEN temp.cn <= 10 THEN Count(DISTINCT id)
       END AS cn_9
FROM   (SELECT id,
               Count(*) AS cn
        FROM   xyz
        GROUP  BY 1) AS temp; 

надеясь получить вывод, как

cn_10cn_9
300400

Но я продолжаю получать эту ошибку,

SQL compilation error: [temp.cn] is not a valid group by expression

Вы не можете ссылаться на cn, так как вы не группируете по нему, что необходимо из-за агрегирования с count. Вам необходимо реализовать выражение case в агрегации - также обратите внимание, что отличные не имеют значения, поскольку Id уже находится в отдельных группах во внутреннем запросе.

Stu 17.05.2022 23:24
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
Четыре эффективных способа центрирования блочных элементов в CSS
Четыре эффективных способа центрирования блочных элементов в CSS
У каждого из нас бывали случаи, когда нам нужно отцентрировать блочный элемент, но мы не знаем, как это сделать. Даже если мы реализуем какой-то...
0
1
14
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы можете использовать выражение case в агрегации, как показано ниже, конечно, не проверено, но работает ли это для вас?

select
  Count(case when cn  > 10 then 1 end) cn_10,
  Count(case when cn <= 10 then 1 end) cn_9
from (
    select id, Count(*) cn
    from xyz
    group by Id
)t; 

спасибо, Стью, решение работает, спасибо и за объяснение, ценю.

Machine_leaning_9 17.05.2022 23:44

Другие вопросы по теме