Последние записи
- TChromium (CEF3), сохранение изображений
- Как в Delphi XE обнулить таймер?
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
7th
Дек
Запрос на выборку из нескольких таблиц
Posted by obzor under sql
Есть три таблицы (картинка ниже).
Необходимо вывести для каждого учителя имя, фамилию и дату старта практики последнего студента.
Т.е. у каждого учителя есть по нескольку студентов, я джоином вывела какому учителю какие студенты соответствуют, но не могу понять как получить именно самого последнего по дате старта и вывести именно его для каждого учителя.
select teachers_table.* --преподаватель
students_table.* --и его последний студент
from ( select t.mentor_id, --код преподавателя
, ( -- и код его последнего студента
select top 1 intern_id
from stud_tearch_spec_table
INNER JOIN students_table
ON stud_teach_spec_table.intern_id=stu dents_table.intern_id
where stud_tearch_spec_table.mentor_id =t.mentor_id
order by pr_st_date DESC ) as id_last_student
from tearcher_table as t
) as lst
INNER JOIN teachers_table ON lst.mentor_id= teachers_table.mentor.id
INNER JOIN students_table ON lst.id_last_student=students_table.intern_id
-- последняя ДАТА практик по КАЖДОМУ преподавателю
select max(pr_st_Date) as last_date, mentor_id
from stud_tearch_spec_table as t
inner join students_table as s on t.intern_id =s.intern_id
group by mentor_id
select ...........
FROM stud_teach_spec_table
INNER JOIN teachers_table ON stud_teach_spec_table.mentor_id= teachers_table.mentor.id
INNER JOIN students_table ON stud_teach_spec_table.intern_id=stu dents_table.intern_id
-- ну скажем так ЭТО у нас было
inner join -- добавим список последних ДАТ практики по каждому преподавателю
( ... см. выше ) as lst on lst.mentor_id =tearchers_table.mentor_id
WHERE -- а теперь зная студента, его преподавателя и дату его последней практики
studens_table.pr_st_date =lst.last_date
Случайные статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)