powered by simpleCommunicator - 2.0.60     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / IBM DB2, WebSphere, IMS, U2 [игнор отключен] [закрыт для гостей] / динамический sql
4 сообщений из 4, страница 1 из 1
динамический sql
    #34564496
wader07
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
У меня классическая задача возникла, но никак не могу разобрацца. Подскажите, плз.
Нужна функция, принимающая имя таблицы и поля, и возвращающая заданное поле, отсортированное по возрастанию.
Думаю примерно так:

CREATE FUNCTION dynSelect (tableName varchar(255), rowName varchar(255))
RETURNS varchar(255)
LANGUAGE SQL
CONTAINS SQL
begin atomic
DECLARE v_dynSQL varchar(600);
declare c cursor for v_dynSQL;
DECLARE res varchar(255);
SET v_dynSQL = 'select ' || rowName || ' from ' || tableName || ' order by ' || rowName || ' ASC';
PREPARE c FROM v_dynSQL;
OPEN c;
FETCH c INTO res;
CLOSE c;
RETURN res;
end^

при этом не разобрался, как возвращать не одно значение, а весь результат.
заранее спасибо
...
Рейтинг: 0 / 0
динамический sql
    #34564778
Mark Barinstein
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
В db2 for LUW вы не можете использовать динамический sql, курсоры в SQL UDF.
Вы можете:
1. Написать external UDF (c, java)
2. Написать хранимаю процедуру, возвращающую result set.
...
Рейтинг: 0 / 0
динамический sql
    #34565550
wader07
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
в таком случае конечно хранимая процедура... но все равно есть проблемы.
пишу так:

drop PROCEDURE dynSelect^
CREATE PROCEDURE dynSelect (tableName varchar(255), colName varchar(255))
LANGUAGE SQL
MODIFIES SQL DATA
DYNAMIC RESULT SETS 1
begin atomic
DECLARE res varchar(255);
DECLARE v_dynSQL varchar(600);
declare c cursor with return for v_dynSQL;
SET v_dynSQL = 'select ' || colName || ' from ' || tableName;
PREPARE c FROM v_dynSQL;
OPEN c;
FETCH c INTO res;
CLOSE c;
end^

1. каким образом вернуть весь столбец вместо первого значения
2. при выполнении функции возвращается ошибка: The cursor "C" is not in a prepared state
...
Рейтинг: 0 / 0
динамический sql
    #34565653
Mark Barinstein
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
CREATE PROCEDURE dynSelect (tableName varchar( 255 ), colName varchar( 255 ))
LANGUAGE SQL
MODIFIES SQL DATA
DYNAMIC RESULT SETS  1 
begin atomic
DECLARE v_dynSQL varchar( 600 );
declare c cursor with return for s1;
SET v_dynSQL = 'select ' || colName || ' from ' || tableName;
PREPARE s1 FROM v_dynSQL;
OPEN c;
end^
...
Рейтинг: 0 / 0
4 сообщений из 4, страница 1 из 1
Форумы / IBM DB2, WebSphere, IMS, U2 [игнор отключен] [закрыт для гостей] / динамический sql
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]