Главная страница
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.47 MB
Время: 0.019 c
14-94093
able
2004-02-06 20:02
2004.02.29
PHP Host


3-93774
EugenePichugin
2004-02-03 18:11
2004.02.29
Вызов хранимой процедуры Oracle из Delphi


14-94138
DiGiTaL_BuSTaRD
2004-02-08 23:25
2004.02.29
Спутниковый инет


4-94252
Игорь В.
2003-12-23 23:07
2004.02.29
API функции для принтера


3-93765
Fom
2004-02-04 10:30
2004.02.29
Как правильно обработать onValidate?