Форум программистов, компьютерный форум, киберфорум
Microsoft Access
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
 Аватар для Kkarn
902 / 292 / 50
Регистрация: 02.12.2014
Сообщений: 1,229

Запрос с группировкой БД Ученики

30.10.2018, 13:10. Показов 1837. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем добрый день.
Не думал, что меня настолько затупит простейшая, на первый взгляд, задачка...
Есть таблица, в которой поля Класс, Фамилия и ДатаРождения.
Нужно создать запрос, который бы выдал в итоге фамилию и дату рождения самого младшего ученика в каждом классе.
Прилагаю базу для примера. В данном конкретном примере в итоговый запрос должны попасть Иванов и Горбатых.

Казалось бы. Создаем запрос с группировкой по классам. В поле "Дата" пишем Max. Без проблем.
А как получить в этом же запросе фамилию того, у кого самая поздняя дата?.. Ведь для этого не подойдут никакие функции типа First и т.д., т.к. они будут также выбирать первую, последнюю и т.п. фамилии в классе... Как получить именно ЗНАЧЕНИЕ того поля фамилии, которому соответствует максимальная дата?..
Спасибо.
Вложения
Тип файла: rar Database.rar (18.3 Кб, 8 просмотров)
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
30.10.2018, 13:10
Ответы с готовыми решениями:

Запрос с группировкой
Приветствую! Ощущаю себя тупым, никогда не работал с Access. Бьюсь уже три часа, но ничего не выходит. Есть таблица Друзья с полями...

Запрос с группировкой по времени
Здравствуйте. Мне нужна помощь в составление запроса. Необходимо сделать группировку записей по времени оказания услуги. SELECT...

Запрос с группировкой по алфавиту
Всем доброго времени суток. Тут на работе начальнику приспичило сделать базу данных детей с 1995 года поступивших а сад. Начал делать Базу...

6
Эксперт MS Access
 Аватар для Eugene-LS
12066 / 5849 / 1494
Регистрация: 05.10.2016
Сообщений: 16,440
30.10.2018, 14:02
Цитата Сообщение от Kkarn Посмотреть сообщение
В данном конкретном примере в итоговый запрос должны попасть Иванов и Горбатых.
Ну прибл. так:
SQL
1
2
3
4
SELECT Таблица1.Класс, MAX(Таблица1.ДатаРождения) AS [Max-ДатаРождения], LAST(Таблица1.Фамилия) AS LastOfФамилия
FROM Таблица1
GROUP BY Таблица1.Класс
ORDER BY MAX(Таблица1.ДатаРождения) DESC;
0
 Аватар для Kkarn
902 / 292 / 50
Регистрация: 02.12.2014
Сообщений: 1,229
30.10.2018, 14:11  [ТС]
Eugene-LS, Неа...
Посмотрите, ваш запрос выдает ПЕТРОВА и Горбатых. А надо ИВАНОВА и Горбатых. Поскольку именно эти два человека имеют самую большую дату в своем классе.

Добавлено через 5 минут
Тут вопрос именно в том, что в запросе как бы сначала нужно отобрать самую максимальную дату в каждой группе (и с этим проблем нет), а потом нужно подобрать соответствующее этой дате значение другого поля - и вот этого я не знаю, как прикрутить в группирующем запросе, т.к. в нем нет, похоже, таких средств, только всякие функции группирующие.
0
Эксперт MS Access
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
30.10.2018, 14:12
Лучший ответ Сообщение было отмечено Kkarn как решение

Решение

Kkarn, попробуйте
SQL
1
2
3
SELECT Таблица1.*
FROM Таблица1
WHERE Код IN (SELECT top 1 Код FROM Таблица1 t WHERE t.Класс=Таблица1.Класс ORDER BY t.ДатаРождения DESC)
1
Эксперт MS Access
 Аватар для Eugene-LS
12066 / 5849 / 1494
Регистрация: 05.10.2016
Сообщений: 16,440
30.10.2018, 14:13
Цитата Сообщение от Kkarn Посмотреть сообщение
Посмотрите, ваш запрос выдает ПЕТРОВА и Горбатых. А надо ИВАНОВА и Горбатых. Поскольку именно эти два человека имеют самую большую дату в своем классе.
Принято!
Ссори!
Покумекаю ....
1
 Аватар для Kkarn
902 / 292 / 50
Регистрация: 02.12.2014
Сообщений: 1,229
30.10.2018, 14:21  [ТС]
mobile, Похоже, именно то, что нужно!) В очередной раз спасибо.
На внешний вид - все не так и просто, как думалось... Надо посидеть, вникнуть в суть такого запроса. Никак не привыкну к структурам "запрос в запросе").
0
Эксперт MS Access
 Аватар для Eugene-LS
12066 / 5849 / 1494
Регистрация: 05.10.2016
Сообщений: 16,440
30.10.2018, 14:27
Цитата Сообщение от Eugene-LS Посмотреть сообщение
А надо ИВАНОВА и Горбатых.
SQL
1
2
SELECT Таблица1.*
FROM Таблица1 INNER JOIN (SELECT Класс AS Klass, MAX(ДатаРождения) AS BD FROM Таблица1 GROUP BY Класс ORDER BY Класс) AS SSD ON (Таблица1.ДатаРождения = SSD.BD) AND (Таблица1.Класс = SSD.Klass);
... Аппаздал
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.10.2018, 14:27
Помогаю со студенческими работами здесь

Запрос с группировкой и суммированием
Здравствуйте! Есть родительская таблица приход: idпри, наименование, количество. Есть дочерняя таблица расход: idрас, idпри,...

Запрос с группировкой и подсчетом
Доброй ночи! Сразу к телу: задание - разработать запрос с выводом сведений об откомандированных абитуриентах с группировкой по причине...

Запрос на выборку с группировкой бд Парковки
Доброго времени суток! Подскажите, пожалуйста у самого мозг не дотягивает. Есть две таблицы со связью один ко многим. 1. т_ОПП с...

Запрос с группировкой и подсчетом количества
Помогите разобраться, не получается сделать запрос: "Определить АТС, которые действуют в одном районе". Сначала считаем, сколько АТС...

Запрос left join с группировкой по 2 полям
Здравствуйте. Есть таблица дата - продукция - масса - движение (приход или расход) Нужно считать итог по разным видам продукции...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru