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

Вниз

Как сделать такой запрос?   Найти похожие ветки 

 
Карелин Артем ©   (2004-02-03 13:25) [0]

Хочу значит переделать хранимую процедуру в запрос.
Смысл такой: идет цикл For select для главной таблицы, внутри которого идет запрос select first(1) из подчиненной таблицы.
Как сделать джойн, который выведет одну таблицу и к каждой записи добавит первую (по заданному порядку сортировки разумеется) запись из дочерней таблицы. А если дочерних записей нет, то Null на этом месте.


 
Sandman25 ©   (2004-02-03 13:28) [1]

select ...
from main,
secondary s1
where main.id = s1.id // связь
and not exists
(select 1
from secondary s2
where s2.id = main.id // связь
and s2.field < s1.field // сортировка
)


 
Sandman25 ©   (2004-02-03 13:28) [2]

Если нужны и NULL, то переделать на left join


 
Johnmen ©   (2004-02-03 13:58) [3]

>Карелин Артем ©

Смысл получения 1 записи неясен... Есть ли критерий того, что эта первая запись именно та, которая нужна ?
Если есть (а иначе это бессмысленно), то этот критерий можно отобразить в where при соединении таблиц.


 
Карелин Артем ©   (2004-02-03 14:08) [4]

Johnmen © (03.02.04 13:58) [3]
Это будет первая при определенном порядке сортировки. Ну и завязаны по ключам таблицы.


 
Johnmen ©   (2004-02-03 14:11) [5]

>Карелин Артем ©
>Это будет первая при определенном порядке сортировки

А значит можно использовать агрегатные ф-ии типа MIN/MAX. Вместо first...
:)


 
Карелин Артем ©   (2004-02-03 14:15) [6]

Johnmen © (03.02.04 14:11) [5]
Действительно. Как-то не приходила мысля использовать Max по отнешению к датам(у меня даты в order by). А зря.



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

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

Наверх




Память: 0.48 MB
Время: 0.031 c
1-93847
Бушин Сергей
2004-02-18 14:44
2004.02.29
Форма в компоненте - передача в компонент наступившего событя


7-94208
sergio_serg
2003-12-08 15:55
2004.02.29
Дайте пожалуйста линки на компоненты работающие с com-портами


7-94198
Nau
2003-12-08 17:35
2004.02.29
Запуск проги до загрузки системы


7-94205
LOX
2003-09-05 14:12
2004.02.29
определить температуру винчестера.


1-93855
Grinder
2004-02-16 16:46
2004.02.29
Resize в ListView