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

Вниз

Обработка информации по типу удаленных процедур   Найти похожие ветки 

 
sunrider   (2003-05-28 00:04) [0]

Привет всем. Мастера поделитесь мнением : Есть необходимость
использовать процедуру на сервере с конструкцией типа
for select ....
where <параметры выбора>
into :<переменные>
do begin
insert into table_name(...) values(...)
end
Вся проблема в том, что число параметров для where величина переменная. Как все это реализовать на стороне клиента понятно,
но не интересно :-) и конечно медленее, чем на сервере.
Не охота так же создавать процедуру на ходу, а потом ее удалять.
Может есть у кого идеи? Заранее благодарю


 
Zacho ©   (2003-05-28 00:17) [1]

1. А сделать запрос типа INSERT INTO ... SELECT ... WHERE ... вместо хранимой процедуры и динамически формировать его не клиенте никак ?

> и конечно медленее, чем на сервере

А проверь :-) Сомневаюсь, что сильно медленнее.
2. Смотри в сторону FB 1.5 и EXECUTE STATEMENT


 
sunrider   (2003-05-28 10:42) [2]

У меня база на dialect 1 не совсем желательно переходить на диалект 3. Про то что ты написал - думал конечно, но есть пару значений первичного ключа, которые нужно задавать. По этому
придеться использовать именно - insert into table_name(...) values(...). Или UDF писать, что ли.


 
Sandman25 ©   (2003-05-28 11:01) [3]

>но есть пару значений первичного ключа, которые нужно задавать.

Можно написать INSERT INTO table1 SELECT para_znacenii1, para_znacenii2, table2.field1, table2.field2 FROM table2


 
AlexSerp ©   (2003-05-28 11:24) [4]

Определи в процедуре максимум нужных тебе параметров.
И делай в ней разбор на заполненность параметров.

if PARAM1 is not null then begin
for select ...
do suspend;
end
if PARAM2 is not null then begin
for select ...
do suspend;
end
if PARAM3 is not null then begin
for select ...
do suspend;
end


 
AlexSerp ©   (2003-05-28 11:25) [5]

Да, забыл.
Там, естественно, можно и комбинации заполненности параметров применять.


 
Zacho ©   (2003-05-28 13:09) [6]


> sunrider (28.05.03 10:42)

Если первичный ключ формируется генератором, то можно INSERT INTO ... SELECT (GEN_ID(MY_GEN,1), ...) FROM ... WHERE ..


 
sunrider   (2003-05-28 14:40) [7]

Спасибо мужики подсказали идею . Попробую оба варианта.



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

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

Наверх




Память: 0.48 MB
Время: 0.017 c
1-60266
vlad1972
2003-06-06 10:23
2003.06.19
Быстрое создание отчетов


3-60071
Rel_
2003-05-28 09:27
2003.06.19
isnert into table


7-60434
alexteam
2003-04-14 10:22
2003.06.19
программа администрации проблема надежности


3-60021
Sergant
2003-05-27 14:41
2003.06.19
ZeosLib и GetTableNames


14-60395
LiLa Ananda
2003-06-02 10:21
2003.06.19
Что ведет мужчину?