Я написал сценарий pl sql для добавления значений, хранящихся в массиве, во временную таблицу. Я использовал «Выполнить немедленно» для выполнения запроса вставки внутри цикла.
Я проверил количество одинарных кавычек и количество запятых, и они закрыты. Тем не менее я получаю код ошибки ORA-00917: отсутствует запятая.
declare
type post_CODS IS VARRAY(34) OF VARCHAR2(20);
type locality_ID IS VARRAY(34) OF NUMBER(9);
pc post_CODS;
Y varchar2(1);
lid locality_ID;
total integer;
begin
Y := 'Y';
lid := locality_ID(2380,3785,8710,17895,20345,24630,26814,28525,29130,31025,31265,32445,36940,40590,54290,83775,83780,83785,83790,83795,88483,93480,94560,96670,1000524,1000628,1000738,1000857,1000988,1001103,1001466,1001575,1001707,1001744);
pc := post_CODS(2822,2739,2822,2372,2817,4314,4300,4726,4300,4884,4314,4314,4300,5719,3026,4314,4314,4314,4314,4314,873,2582,2817,4314,5723,5440,2083,2575,873,2372,5440,5440,5715,5440);
total := lid.count;
FOR i in 1 .. total LOOP
execute immediate 'insert into tmp_ref_lc_pc_cods values('||lid(i)||','||pc(i)||','||Y||',89987,'||sysdate||')';
END LOOP;
END;
Это ошибка, которую я получаю
ORA-00917: missing comma
ORA-06512: at line 14
00917. 00000 - "missing comma"
Я работаю в оракуле.