Предыдущая тема :: Следующая тема |
Автор |
Сообщение |
khm Гость
|
Добавлено: Сб Май 29 2004 14:18 Заголовок сообщения: Лекгий вопрос для спецов в SQL...запрос... |
|
|
Имеется MS SQLServer2000. В базе данных следующие таблицы
===========
Таблица T1 (таблица "Регион")
-----------
Region_id -идентификатор региона(int)
RegionCode -код региона,например для Москвы 7095(char[12])
RegionName -наименование региона(char[64])
IsEnabled -вкл/выкл регион(bit) 0=выкл 1=вкл
===========
===========
Таблица T2 (таблица "Тариф на регион")
-----------
Rate_id -идентификатор тарифа(int)
Region_id -идентификатор региона(int)
ActualDate -дата, с которой действует данный тариф на данный регион(datetime)
Rate -тариф(money)
===========
В таблице T1 лежат записи о всех регионах, в таблице T2
хранятся данные по тарифам на регионы. В таблице T2 может
быть несколько записей тарифов по каждому региону, различающиеся
датой, с которой актуален данный тариф.
Две таблицы имеют связь типа "один-ко-многим" по полю Region_id.
Вопрос в следующем: как мне соорудить выборку (SELECT) данных из этих таблиц,
чтобы в результирующей выборке были следущие записи:
Region_id
RegionName
RegionCode
ActualDate
Rate
т.е. для определенных (например, включенных) регионов из T1 выбрать самые "свежие" по дате
тарифы из T2. Надо чтобы ответ содержал готовый код запроса, а не ссылки на определенные
команды SQL (перепробовал select со многими параметрами - не получается).
|
|
Вернуться к началу |
|
|
stvaa
Зарегистрирован: 23.04.2004 Сообщения: 12 Откуда: Москва
|
Добавлено: Сб Май 29 2004 14:45 Заголовок сообщения: Кривенький запрос |
|
|
Возможно, можно придумать и получше, но у меня не получилось пока: Код: | Select t1.region_id, t1.RegionName, t1.RegionCode, t2.ActualDate, t2.Rate
from t1, t2 where t1.region_id=t2.region_id and
t2.actualdate = (select max(t2.actualdate) from t2 where t1.region_id=t2.region_id)
and t1.isenabled=1 |
По-моему, как раз выдает то, что надо. |
|
Вернуться к началу |
|
|
khm Гость
|
Добавлено: Сб Май 29 2004 18:27 Заголовок сообщения: |
|
|
Спасибо, вроде показывает то, что надо. Если будут поправки к запрсу - потом приму к сведению, а пока использую этот. |
|
Вернуться к началу |
|
|
|