Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2007.05.20;
Скачать: CL | DM;

Вниз

Помогите построить запрос   Найти похожие ветки 

 
dmdel ©   (2007-05-03 18:39) [0]

Здраствуйте, помогите построить запрос.
СУБД - FB 1.5
Есть несколько таблиц:
1. Dis : ID тип integer, Name Varchar(100); PK-id //Это список заболеваний
2. Cook : ID тип integer, Name Varchar(100); PK-id// Это способы приготовления какого-либо блюда
3. Rec : ID тип integer, Name Varchar(100); PK-id// Это список блюд
4. Dis_Exc_Cook: ID тип integer, Id_Cook тип integer, Id_Dis; PK-id, внешние ключи: Id_Cook=Cook.id и Id_Dis=Dis.id// В этой таблице хранится информация, при каком заболевании- какой способ приготовления блюда исключить
5. Rec_Cook: ID тип integer, Id_Cook тип integer, Id_Rec; PK-id, внешние ключи: Id_Cook=Cook.id и Id_Rec=Rec.id// В этой таблице хранится способы приготовления того или иного блюда.
Нужно сформировать запрос, который бы при вводе Dis.id выдавал список блюд, которые ему можно употреблять. Надеюсь понятно объяснил. У меня есть вариант с вложенными запросами, но их получается 3 штуки. Думаю, что это можно сделать проще. Предложите свой вариант. Заранее спасибо


 
Asail   (2007-05-03 19:15) [1]

SELECT *
FROM Rec
WHERE ID not in (
 SELECT R.ID
 FROM Dis_Exc_Cook DE
   LEFT JOIN Cook C ON (DE.Id_Cook=C.ID)
   LEFT JOIN Dis D ON (DE.Id_Dis=D.ID)
   LEFT JOIN Rec_Cook R ON (R.Id_Cook=C.ID)
 WHERE D.ID = :ID
)


Типа такого? (Не проверял, правда, но должно работать)



Страницы: 1 вся ветка

Текущий архив: 2007.05.20;
Скачать: CL | DM;

Наверх




Память: 0.46 MB
Время: 0.14 c
1-1174565452
thecat
2007-03-22 15:10
2007.05.20
Где взять mmx.dcu?


15-1177076711
Ringo
2007-04-20 17:45
2007.05.20
Вот те раз! А я думал, - Медведев...


15-1177397126
WondeRu at work
2007-04-24 10:45
2007.05.20
Рефакторинг в Delphi


11-1150662182
DevilDevil
2006-06-19 00:23
2007.05.20
"PROJECT Informator" - утилитка в помощь KOL программисту


3-1172754051
svs_sergo
2007-03-01 16:00
2007.05.20
Глюк в DBGrid е - самопроизвольно меняет значение