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

Знатокам SQL - помогите с запросом!!!

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
Ганчиков Михаил
Гость





СообщениеДобавлено: Вс Апр 25 2004 11:29    Заголовок сообщения: Знатокам SQL - помогите с запросом!!! Ответить с цитатой

Товарищи, нужна ваша СРОЧНАЯ ПОМОЩЬ!!!

Есть 3 таблицы (с указанием реквизитов):

Магазины (Код магазина|Наименование|Дилер|Район|Адрес|Телефон|),

Детали (Код детали|Наименование|... и т.д.),

Реестр (Код записи|Код магазина|Код детали|Цена)

Нужно написать запрос, выводящий все магазины, торгующие указанной деталью (предположим, 'КОЛЕСО') с указанием цены по которой продается деталь. Вот что я написал:

SELECT Наименование, Дилер, Район, Адрес, Телефон, Реестр.[Цена детали (руб)]
FROM Магазины,Реестр
WHERE Магазины.[Код магазина] = Реестр.[Код магазина] AND Магазины.[Код магазина] IN (SELECT [Код магазина] FROM Реестр WHERE Реестр.[Код детали] IN
(SELECT [Код детали] FROM Детали WHERE Детали.Наименование = 'Колесо'))

Проблема в том, что в этом случае выдаются все записи в таблице Магазины, коды которых указаны в таблице Реестр. А нужно, чтобы только те, где Реестр.Код детали = Детали.Код детали и т.д. (по запросу должно быть понятно...). Очень жду вашей помощи, заранее благодарен, Михаил.

p.s. был получен ответ, содержащий вот такой запрос:

SELECT Наименование, Дилер, Район, Адрес, Телефон, Реестр.[Цена детали (руб)]
FROM Магазины INNER JOIN Реестр ON Магазины.[Код магазина] = Реестр.[Код магазина] INNER JOIN Детали ON Детали.[Код детали] = Реестр.[Код детали] WHERE Детали.Наименование = 'Колесо'

На что Access написал - ошибка синтаксиса. В чем проблема, нельзя использовать двойной INNER JOIN???
ПОМОГИТЕ, КУРСОВИК СДАВАТЬ УЖЕ ЧЕРЕЗ НЕДЕЛЮ!!!
Вернуться к началу
Гость






СообщениеДобавлено: Пн Апр 26 2004 01:04    Заголовок сообщения: Ответить с цитатой

Я создала все, как дано, и проверила, так у меня сработало:
SELECT Наименование, Дилер, Район, Адрес, Телефон, Реестр.[Цена], Детали.[Наименование]
FROM Магазины,Реестр,Детали
WHERE Магазины.[Код магазина] = Реестр.[Код магазина]
AND Детали.[Код детали] = Реестр.[Код детали]
AND Реестр.[Код детали] IN (SELECT [Код детали] FROM Детали WHERE Детали.[Наименование] = 'Колесо')

Хотя пришлось добавить некоторые данные и из Деталей Smile.

В оригинале под Delphi звучало так
(может я где ошиблась при переводе):
SELECT m1.'Наименование', m1.'Дилер', r1.'Цена', d1.'Наименование'
FROM mag m1,reestr r1, detal d1
WHERE m1.'Код магазина' = r1.'Код магазина'
AND d1.'Код детали' = r1.'Код детали'
AND r1.'Код детали' IN (SELECT d3.'Код детали' FROM detal d3 WHERE d3.'Наименование' = 'Колесо')
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: 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
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...