Хобрук: Ваш путь к мастерству в программировании

SQL SUM и COUNT для нескольких столбцов

У меня есть данные в MS Access, например:

+------------+-----------+
| DateStart  | PATIssued |
+------------+-----------+
| 12/12/2004 | Yes       |
+------------+-----------+
| 13/12/2004 | No        |
+------------+-----------+
| 14/12/2004 | No        |
+------------+-----------+
| 12/12/2004 | No        |
+------------+-----------+
| 12/12/2004 | Yes       |
+------------+-----------+
| 14/12/2004 | No        |
+------------+-----------+
| 13/12/2004 | Yes       |

Я хочу подсчитать количество записей в день за прошедшую неделю по дням недели, а в другом столбце подсчитать записи, где PATIssued = Yes

Таким образом, результаты будут выглядеть так:

Date       DayCount PATCount
Monday        3        2
Tuesday       2        1
Wednesday     2        0

я дошел до

SELECT Format(DateValue(DateStart),"dddd") AS DayOFWeek,  PATIssuedYN,
Count(Table1.DateStart) AS DayCount,
Sum(IIf([PATIssuedYN]="Yes",1,))
FROM Table1
WHERE (((Table1.DateStart) Between DateAdd("d",-7,Now()) And Now()))
GROUP BY DateValue(DateStart), PATIssuedYN;

Проблема в том, что это возвращает

Date       PATIssuedYN   DayCount PATCount
Monday        No            1         
Monday        Yes           2        2
Tuesday       No            1
Tuesday       Yes           1        1
Wednesday     No            2        
Wednesday     Yes           0        0

Где понедельник 12.12, вторник 13.12, среда 14.12.

10.04.2017

  • удалить PATIssuedYN из вашего выбора и сгруппировать по 10.04.2017
  • Используйте условие, что PATIssuedYN = Yes 10.04.2017
  • @ЕвгенийКондратенко, что исказило бы значение DayCount 10.04.2017

Ответы:


1

поскольку вы не хотите возвращать столбец PatIssuedYN, удалите его из своего выбора и своей группы:

SELECT Format(DateValue(DateStart),"dddd") AS DayOFWeek,
Count(Table1.DateStart) AS DayCount,
Sum(IIf([PATIssuedYN]="Yes",1,))
FROM Table1
WHERE (((Table1.DateStart) Between DateAdd("d",-7,Now()) And Now()))
GROUP BY DateValue(DateStart);
10.04.2017
Новые материалы

Не зря же это называют интеллектом
Стек — C#, Oracle Опыт — 4 года Работа — Разведывательный корпус Мне пора служить Может быть, я немного приукрашиваю себя, но там, где я живу, есть обязательная военная служба на 3..

LeetCode Проблема 41. Первый пропущенный положительный результат
LeetCode Проблема 41. Первый пропущенный положительный результат Учитывая несортированный массив целых чисел, найдите наименьшее пропущенное положительное целое число. Пример 1: Input:..

Расистский и сексистский робот, обученный в Интернете
Его ИИ основан на предвзятых данных, которые создают предрассудки. Он словно переходит из одного эпизода в другой из серии Черное зеркало , а вместо этого представляет собой хронику..

Управление состоянием в микрофронтендах
Стратегии бесперебойного сотрудничества Микро-фронтенды — это быстро растущая тенденция в сфере фронтенда, гарантирующая, что удовольствие не ограничивается исключительно бэкэнд-системами..

Декларативное и функциональное программирование в стиле LINQ с использованием JavaScript с использованием каррирования и генератора ...
LINQ - одна из лучших функций C #, которая обеспечивает элегантный способ написания кода декларативного и функционального стиля, который легко читать и понимать. Благодаря таким функциям ES6,..

Структуры данных в C ++ - Часть 1
Реализация общих структур данных в C ++ C ++ - это расширение языка программирования C, которое поддерживает создание классов, поэтому оно известно как C с классами . Он используется для..

Как я опубликовал свое первое приложение в App Store в 13 лет
Как все началось Все началось три года назад летом после моего четвертого класса в начальной школе. Для меня, четвертого класса, лето кажется бесконечным, пока оно не закончится, и мой отец..