Гость
Форумы / Microsoft Access [игнор отключен] [закрыт для гостей] / Как посчитать уникальные значения про помощи DISTINCT / 6 сообщений из 6, страница 1 из 1
21.05.2019, 17:49
    #39815962
quickstar
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как посчитать уникальные значения про помощи DISTINCT
Доброго дня!

на форумах полно решений типа
Код: sql
1.
2.
3.
SELECT Имя, COUNT(*) AS Скушал
FROM (SELECT DISTINCT Имя, Скушал FROM Таблица)
GROUP BY Имя



а вот как при сложном запросе это применить, не разобрался.
не хватает знаний, прошу помощи.

Задача: посчитать уникальное количество значений "ФИОклиента" в текущем запросе

Код: sql
1.
2.
3.
4.
5.
PARAMETERS [Формы]![з_кво_учеников_в2]![fil_status] Short, [Формы]![з_кво_учеников_в2]![fil_filial] Short;
SELECT Count(Клиенты.КодКлиента) AS Учеников, MonthName(Month([ДатаЗанятия])) AS Месяц, Занятия.Педагог, Year([ДатаЗанятия]) AS Год, Клиенты.Статус, Занятия.Филиал, Занятия.Курс
FROM Занятия RIGHT JOIN Клиенты ON Занятия.ФИОребенка = Клиенты.КодКлиента
GROUP BY MonthName(Month([ДатаЗанятия])), Занятия.Педагог, Year([ДатаЗанятия]), Клиенты.Статус, Занятия.Филиал, Занятия.Курс
HAVING (((Year([ДатаЗанятия]))=Year(Now())) AND ((Клиенты.Статус)=[Формы]![з_кво_учеников_в2]![fil_status]) AND ((Занятия.Филиал)=[Формы]![з_кво_учеников_в2]![fil_filial]));
...
Рейтинг: 0 / 0
21.05.2019, 17:51
    #39815964
quickstar
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как посчитать уникальные значения про помощи DISTINCT
сорри, вот верный запрос, в котором нужно посчитать
Код: sql
1.
2.
3.
4.
5.
PARAMETERS [Формы]![з_кво_учеников_в2]![fil_status] Short, [Формы]![з_кво_учеников_в2]![fil_filial] Short;
SELECT Count(Занятия.ФИОребенка) AS Учеников, MonthName(Month([ДатаЗанятия])) AS Месяц, Занятия.Педагог, Year([ДатаЗанятия]) AS Год, Клиенты.Статус, Занятия.Филиал, Занятия.Курс
FROM Занятия RIGHT JOIN Клиенты ON Занятия.ФИОребенка = Клиенты.КодКлиента
GROUP BY MonthName(Month([ДатаЗанятия])), Занятия.Педагог, Year([ДатаЗанятия]), Клиенты.Статус, Занятия.Филиал, Занятия.Курс
HAVING (((Year([ДатаЗанятия]))=Year(Now())) AND ((Клиенты.Статус)=[Формы]![з_кво_учеников_в2]![fil_status]) AND ((Занятия.Филиал)=[Формы]![з_кво_учеников_в2]![fil_filial]));
...
Рейтинг: 0 / 0
21.05.2019, 18:08
    #39815974
sdku
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как посчитать уникальные значения про помощи DISTINCT
Хочется,перед тем как отвечать, протестировать рекомендуемое
Поэтому прошу выложить запрос с источником(таблицами)
...
Рейтинг: 0 / 0
21.05.2019, 18:19
    #39815980
sdku
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как посчитать уникальные значения про помощи DISTINCT
...
Рейтинг: 0 / 0
21.05.2019, 18:19
    #39815981
quickstar
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как посчитать уникальные значения про помощи DISTINCT
sdku, благодарю за желание помочь.
направляю базу.
...
Рейтинг: 0 / 0
21.05.2019, 18:39
    #39815994
quickstar
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как посчитать уникальные значения про помощи DISTINCT
sdku, методом проб и ошибок нашел решение)))
сделал путем двух запросов.
В первом запросе подготовил все данные (вытягивал из двух таблиц)
Во втором запросе вот так данные обраюотал и вышло то, что нужно!

Код: sql
1.
2.
3.
4.
5.
TRANSFORM Count(T_table.ФИОребенка) AS Учеников
SELECT T_table.Курс, T_table.Филиал, T_table.Педагог
FROM (SELECT DISTINCT Запрос0.ФИОребенка, Месяц, Курс, Филиал, Педагог FROM Запрос0)  AS T_table
GROUP BY T_table.Курс, T_table.Филиал, T_table.Педагог
PIVOT T_table.Месяц;



sdku, еще раз благодарю за помощь.
йяхоу!!!
...
Рейтинг: 0 / 0
Форумы / Microsoft Access [игнор отключен] [закрыт для гостей] / Как посчитать уникальные значения про помощи DISTINCT / 6 сообщений из 6, страница 1 из 1
Целевая тема:
Создать новую тему:
Автор:
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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