Последовательность двух курсоров в процедуре - PullRequest
0 голосов
/ 23 октября 2018

У меня следующая проблема с процедурой:

CREATE PROCEDURE TEST() 
LANGUAGE SQL
BEGIN

DECLARE V_TEST VARCHAR(100);
DECLARE V_TEST_EXT VARCHAR(100);
DECLARE SQLCODE INTEGER DEFAULT -1;
DECLARE RET_CODE INTEGER DEFAULT -2;
DECLARE LIST_CMD VARCHAR(512);
DECLARE LIST_CMD_EXT VARCHAR(512);

DECLARE CUR_TEST CURSOR WITH RETURN FOR LIST_STMT;
DECLARE CUR_TEST_EXT CURSOR WITH RETURN FOR LIST_EXT_STMT;

DECLARE CONTINUE HANDLER FOR SQLEXECPTION SET RET_CODE = SQLCODE;

SET LIST_CMD = 'SELECT TEST FROM TESTTAB';
PREPARE LIST_STMT FROM LIST_CMD;

OPEN CUR_TEST;
FETCH CUR_TEST INTO V_TEST;
    WHILE (RET_CODE <> 100) DO
        FETCH CUR_TEST INTO V_TEST;
    END WHILE;
CLOSE CUR_TEST;

SET LIST_CMD_EXT = 'SELECT TEST FROM TESTTAB';
PREPARE LIST_STMT_EXT FROM LIST_CMD_EXT;

OPEN CUR_TEST_EXT;
    FETCH CUR_TEST_EXT INTO V_TEST_EXT;
    WHILE (RET_CODE <> 100) DO
        FETCH CUR_TEST_EXT INTO V_TEST_EXT;
    END WHILE;
CLOSE CUR_TEST_EXT;

END;

Проблема, с которой я столкнулся, заключается в том, что процедура выполняет первый цикл курсора, но игнорирует второй.Я попытался добавить BEGIN и END в каждый цикл, но это тоже не помогло.

Я работаю с DB2 v10.5 Windows.Мне нужно, чтобы это работало как процедура.Есть ли способ заставить процедуру запустить оба цикла?

Спасибо за вашу помощь .-

1 Ответ

0 голосов
/ 23 октября 2018

Вы не сбрасываете переменную RET_CODE перед обработкой 2-го курсора.Используйте что-то вроде этого:

SET RET_CODE = 0;
OPEN CUR_TEST_EXT;
...

Кстати, не объявляйте курсор с помощью предложения WITH RETURN, если вы обрабатываете этот курсор внутри процедуры.

...