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

Вниз

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

 
tria ©   (2004-02-02 14:26) [0]

Есть три таблицы:

Docs - таблица документов
Num:Integer;
IdKlient:integer;
...

Klients - таблица клиентов
Id:integer;
Name:VarChar(50)
IdRegion:integer;

Regions - таблица регионов
Id:Integer;
Name:VarChar(50)

Нужно получить отчет вида:
Docs.Num, Klients.Name, Regions.Name

При этом в таблице Docs IdKlient может быть null, в таблице Klients IdRegion тоже может быть null. Получается вроде как два вложенных left join.
БД - FireBird.


 
Deniz ©   (2004-02-02 14:31) [1]

select d.num, k.name KlientName, r.name RegionName
from Docs d
left join Klients k on (d.IdKlient = k.Id)
left join Regions r on (k.IdRegion = r.Id)
order by d.num, k.name, r.name

Вроде так должно работать!


 
tria ©   (2004-02-02 15:22) [2]

Не совсем так как хотелось бы. Если у клиента не указан регион, то имя клиента не выводится. Или я чего-то напутал.


 
Johnmen ©   (2004-02-02 15:27) [3]

или напутал
или добавить ... and (k.IdRegion is not null)


 
tria ©   (2004-02-02 15:30) [4]

Я ошибся. Все работает. Большое спасибо.



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

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

Наверх




Память: 0.47 MB
Время: 0.039 c
1-79889
Сергей Петров
2004-02-10 01:20
2004.02.25
Проблема с midas.dll


9-79529
Jenaxx
2003-08-09 12:19
2004.02.25
Я скачал из Samples исходник Quest это типа рпг какой то а она...


3-79644
Dima
2004-01-31 21:51
2004.02.25
Пустые ADO DataSets


1-79780
Tananda
2004-02-11 16:09
2004.02.25
Не останавливается на Breakpoint


14-80289
тихий вовочка
2004-02-05 07:34
2004.02.25
Как давно вы занимались креативом?