У меня проблема с процедурой mu, которая вставляет повторяющуюся последнюю запись в таблицу.
пример, когда я вставил INSERT..... 'AAA', я получил строки в таблице 'AAA' и 'AAA'
Вместо того, чтобы поместить DBMS()... в код, я получил две записи. Я использую триггер и последовательность для идентификатора столбца в HistoriaDismissDate, но они в хорошем состоянии. Я проверяю, сбросил ли я триггер и последовательность, и это та же ситуация.
Я также использую viewDate, но это представление получает ОДНУ запись, а не две.
мой код
CREATE OR REPLACE PROCEDURE ChangeDismissDate
IS
v_id VARCHAR2(11);
v_dateBhd DATE := TO_DATE('20491231','yyyymmdd');
v_dateDismiss DATE := TO_DATE('20491231','yyyymmdd');
v_login VARCHAR2(50);
last_id NUMBER :=0;
CURSOR cur IS
select EMP_NO, LOGIN, ODEJSCIE_BHD, ODEJSCIE_OLD FROM viewDate;
BEGIN
OPEN cur;
LOOP
FETCH cur INTO v_id,v_login,v_dateBhd,v_dateDismiss;
DBMS_OUTPUT.put_line(v_id || ' ' || v_login || ' ' || v_dateBhd || ' ' || v_dateDismiss);
UPDATE employee_tab SET DISMISS_DATE = v_dateBhd WHERE EMP_NO = v_id;
COMMIT;
INSERT INTO HistoriaDismissDate(CUSTOMER_ID,LOGIN, DATE_CHANGE, DATE_BHD, DATE_DISMISS)
VALUES(v_id,v_login, sysdate, v_dateBhd, v_dateDismiss);
COMMIT;
EXIT WHEN cur%NOTFOUND;
END LOOP;
CLOSE cur;
EXCEPTION
WHEN NO_DATA_FOUND
THEN
DBMS_OUTPUT.put_line (DBMS_UTILITY.format_error_stack);
WHEN OTHERS
THEN
DBMS_OUTPUT.put_line (DBMS_UTILITY.format_error_stack);
END;
/
EXIT WHEN cur%NOTFOUND;
сразу послеFETCH cur INTO
- person Nick Krasnov   schedule 21.11.2012