Главная страница
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.066 c
15-1176785713
Задача
2007-04-17 08:55
2007.05.20
Задача


2-1178037815
Антон Шестаков
2007-05-01 20:43
2007.05.20
Меню как в Nero


4-1166351587
Windows
2006-12-17 13:33
2007.05.20
WinSock функция определения коннекта


15-1176806589
икс-игрик-й
2007-04-17 14:43
2007.05.20
Помогите решить задачки по физике(кто решит отблагодарю)


2-1177764896
Cj
2007-04-28 16:54
2007.05.20
OpenProcess