Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Лекгий вопрос для спецов в SQL...запрос...

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
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    Заголовок сообщения: Ответить с цитатой

Спасибо, вроде показывает то, что надо. Если будут поправки к запрсу - потом приму к сведению, а пока использую этот.
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...