Главная страница
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.027 c
1-60229
Nucl
2003-06-05 08:59
2003.06.19
Обработка большого Excel файла


1-60265
AlexanderG
2003-06-05 19:57
2003.06.19
Список доступных принтеров


14-60381
Тих
2003-06-01 13:33
2003.06.19
_alloca - аналог в Delphi или-какая С runtimeDLL её экспортирует?


8-60269
Alexanders
2003-02-18 10:01
2003.06.19
Вывод несколько картинок на форму в миниатюре


14-60369
Rzhevskiy
2003-06-01 17:38
2003.06.19
Экзамен уже завтра, а темы сочинений я ещё не знаю....