Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Составление запроса 
V
    Опции темы
blur
Дата 27.6.2006, 21:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 126
Регистрация: 9.11.2004

Репутация: нет
Всего: 1



Всем приветик,
Помогите составить запросик:
Есть таблица, в которой храняться поступления в школы:

Student_Id    Begin_Date    End_Date     Grade_level ...
   100            2005-01-01    2005-01-01        10
   100            2005-01-01         null                11
   200            2005-01-01         null                  9
        ...    .........        ........       ...



Мне нужно получить всех студентов(без повторений) и при этом самые последние поступления каждого студента. Что-то никак не могу допарить как такое сделать   smile 






 
PM MAIL   Вверх
chief39
Дата 27.6.2006, 21:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


карманная тигра
***


Профиль
Группа: Участник Клуба
Сообщений: 1631
Регистрация: 20.5.2005
Где: Киев

Репутация: 8
Всего: 77



Во первых:

Что значит "без повторений"?
Я так понимаю, каждый студент записан там один раз.
Или логика предполагает, что любой студент может быть зарегистрирован несколько раз? То есть несколько раз отучился в школе?
Или запись на каждый период времени(если он переходил из школы в школу) ?
 


--------------------
Люди - это свечи. Они либо горят, либо их - в жопу!(с)

PM MAIL   Вверх
blur
Дата 27.6.2006, 21:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 126
Регистрация: 9.11.2004

Репутация: нет
Всего: 1



Цитата(chief39 @ 27.6.2006,  21:24)
Во первых:

Что значит "без повторений"?
Я так понимаю, каждый студент записан там один раз.
Или логика предполагает, что любой студент может быть зарегистрирован несколько раз? То есть несколько раз отучился в школе?
Или запись на каждый период времени(если он переходил из школы в школу) ?

Студент может быть зарегестрирован в этой таблице несколько раз: зарегестрировался, поучился, надоело, ушел, опять зарегестрировался.... Записей на период нету. 
PM MAIL   Вверх
LSD
Дата 27.6.2006, 21:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



Ну что-то типа:
Код
select s.name, g.begin_date from
  (select student_id, max(begin_date) from graduate group by student_id) g
  right join students s on s.id = g.student_id
 


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Akina
Дата 27.6.2006, 21:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 13
Всего: 454



Писано на коленке, но идея, полагаю, ясна
Код

Select *
From Students
   Join 
   (
      Select Student_Id, Max(Begin_Date)
      From Students
      Group By Student_Id
   ) As Q1
   On     Students.Student_Id = Q1.Student_Id 
      AND Students.Begin_Date = Q1.Begin_Date 
 


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
chief39
Дата 27.6.2006, 21:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


карманная тигра
***


Профиль
Группа: Участник Клуба
Сообщений: 1631
Регистрация: 20.5.2005
Где: Киев

Репутация: 8
Всего: 77



Тогда так:

Код

select student_id, max(begin_date)
from   periods
group by student_id    


Но вообще лучше бы ввести в эту табличку поле ID(SID или ещё как-нибудь) для идентификации не студента а ЗАПИСИ.
Тогда можно красиво выбирать всю строку, а не просто айди студента с последней датой

Добавлено @ 22:02 
Мляха... таблиц набежало.. у каждого свои... smile))

blur, скажи названия таблиц(для единообразия нелпа smile ) и уточни какой резалтсет тебе нужен в итоге. 


--------------------
Люди - это свечи. Они либо горят, либо их - в жопу!(с)

PM MAIL   Вверх
blur
Дата 27.6.2006, 22:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 126
Регистрация: 9.11.2004

Репутация: нет
Всего: 1



Цитата(Akina @ 27.6.2006,  21:56)
Писано на коленке, но идея, полагаю, ясна
Код

Select *
From Students
   Join 
   (
      Select Student_Id, Max(Begin_Date)
      From Students
      Group By Student_Id
   ) As Q1
   On     Students.Student_Id = Q1.Student_Id 
      AND Students.Begin_Date = Q1.Begin_Date 

Самое то   smile Совсем недавно начал разбираться с join-ами  smile

Добавлено @ 22:49 
А запросик получился вот такой:
Код

SELECT *
FROM ST_ENROLLMENT
JOIN (

SELECT STUDENT_ID AS S1, MAX( BEGIN_ENROLLMENT_DATE ) AS MAX_D
FROM ST_ENROLLMENT
GROUP BY S1
) AS Q2 ON ST_ENROLLMENT.STUDENT_ID = Q2.S1
AND ST_ENROLLMENT.BEGIN_ENROLLMENT_DATE = Q2.MAX_D

 

Это сообщение отредактировал(а) blur - 27.6.2006, 22:46
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0752 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.