Postgresql plpgsql:在“或”附近出现语法错误&引用;第66行:结束;
当我试图在Postgres服务器中创建此函数时,它给了我一个奇怪的错误: 在“;”处或附近出现语法错误Postgresql plpgsql:在“或”附近出现语法错误&引用;第66行:结束;,postgresql,plpgsql,Postgresql,Plpgsql,当我试图在Postgres服务器中创建此函数时,它给了我一个奇怪的错误: 在“;”处或附近出现语法错误 第67行:结束 代码如下: CREATE OR REPLACE FUNCTION "AGMI".make_process_detail(numeric,numeric) RETURNS text AS $BODY$ DECLARE i_prog_ver_id ALIAS FOR $1; i_priorityMfr_che
第67行:结束 代码如下:
CREATE OR REPLACE FUNCTION "AGMI".make_process_detail(numeric,numeric)
RETURNS text AS
$BODY$
DECLARE
i_prog_ver_id ALIAS FOR $1;
i_priorityMfr_checker ALIAS FOR $2;
i_success text;
i_error_message text;
v_rankset_Rec record;
v_counter integer;
BEGIN
v_counter = 304;
DELETE FROM "AGMI"."PROCESSING_DETAIL"
WHERE "PROG_VER_ID" = i_prog_ver_id;
INSERT INTO "AGMI"."PROCESSING_DETAIL"("PROG_VER_ID", "RANK_SET_CODE", "PROCESS", "RUN_NUMBER", "FLAG", "START_TIME", "WHEN_DONE", "TIME_TAKEN", "PASS_NUMBER")
VALUES (i_prog_ver_id,0,'PMODULE',301,0,Null,Null,Null,0);
IF i_priorityMfr_checker = 1 THEN
INSERT INTO "AGMI"."PROCESSING_DETAIL"("PROG_VER_ID", "RANK_SET_CODE", "PROCESS", "RUN_NUMBER", "FLAG", "START_TIME", "WHEN_DONE", "TIME_TAKEN", "PASS_NUMBER")
VALUES (i_prog_ver_id,0,'PRIORITIESMFR',302,0,Null,Null,Null,0);
ELSE IF i_priorityMfr_checker = 0 THEN
INSERT INTO "AGMI"."PROCESSING_DETAIL"("PROG_VER_ID", "RANK_SET_CODE", "PROCESS", "RUN_NUMBER", "FLAG", "START_TIME", "WHEN_DONE", "TIME_TAKEN", "PASS_NUMBER")
VALUES (i_prog_ver_id,0,'PRIORITIES',302,0,Null,Null,Null,0);
ELSE
i_error_message := "Invalid input for 2nd entry";
RETURN i_error_message;
END IF;
INSERT INTO "AGMI"."PROCESSING_DETAIL"("PROG_VER_ID", "RANK_SET_CODE", "PROCESS", "RUN_NUMBER", "FLAG", "START_TIME", "WHEN_DONE", "TIME_TAKEN", "PASS_NUMBER")
VALUES (i_prog_ver_id,0,'FMODULE',303,0,Null,Null,Null,0);
FOR v_rankset_Rec IN
SELECT distinct "RANK_SET_CODE"
FROM "AGMI"."RANKSET"
WHERE "PROG_VER_ID" = i_prog_ver_id
ORDER BY "RANK_SET_CODE"
LOOP
INSERT INTO "AGMI"."PROCESSING_DETAIL"("PROG_VER_ID", "RANK_SET_CODE", "PROCESS", "RUN_NUMBER", "FLAG", "START_TIME", "WHEN_DONE", "TIME_TAKEN", "PASS_NUMBER")
VALUES (i_prog_ver_id,v_rankset_Rec."RANK_SET_CODE",'FRANKSET',v_counter,0,Null,Null,Null,0);
v_counter = v_counter+1;
INSERT INTO "AGMI"."PROCESSING_DETAIL"("PROG_VER_ID", "RANK_SET_CODE", "PROCESS", "RUN_NUMBER", "FLAG", "START_TIME", "WHEN_DONE", "TIME_TAKEN", "PASS_NUMBER")
VALUES (i_prog_ver_id,v_rankset_Rec."RANK_SET_CODE",'NF',v_counter,0,Null,Null,Null,0);
v_counter = v_counter+1;
INSERT INTO "AGMI"."PROCESSING_DETAIL"("PROG_VER_ID", "RANK_SET_CODE", "PROCESS", "RUN_NUMBER", "FLAG", "START_TIME", "WHEN_DONE", "TIME_TAKEN", "PASS_NUMBER")
VALUES (i_prog_ver_id,v_rankset_Rec."RANK_SET_CODE",'SAT',v_counter,0,Null,Null,Null,0);
v_counter = v_counter+1;
END LOOP;
i_success := 'Success';
RETURN i_success;
END;
$BODY$
LANGUAGE 'plpgsql' VOLATILE;
ALTER FUNCTION "AGMI".make_process_detail(numeric,numeric) OWNER TO postgres;
更新:现在包含完整的功能
知道最后一行的错误是什么吗
ELSE IF i_priorityMfr_checker = 0 THEN
需要
ELSIF i_priorityMfr_checker = 0 THEN
需要
ELSIF i_priorityMfr_checker = 0 THEN
ELSEIF
也有效(中间是“E”)ELSEIF
也有效(中间是“E”)我不知道postgres,但是如果省略后面的分号会怎么样?谢谢你的建议。我确实使用了CREATEFUNCTION语句,所以这不会是问题所在。错误消息指向下一行末尾;我在这里找不到任何奇怪的东西,因为我总是使用END作为结束块的最后语句。还有@Kay,我确实试图省略后面的分号,它显示了相同的错误。其他人知道这里发生了什么吗?您缺少了结束标记$body$
和语言规范我确实包含了它们,但仍然向我显示了相同的错误。还有其他想法吗,没有名字的马?我不知道postgres,但是如果省略后面的分号会怎么样?谢谢你的建议。我确实使用了CREATEFUNCTION语句,所以这不会是问题所在。错误消息指向下一行末尾;我在这里找不到任何奇怪的东西,因为我总是使用END作为结束块的最后语句。还有@Kay,我确实试图省略后面的分号,它显示了相同的错误。其他人知道这里发生了什么吗?您缺少了结束标记$body$
和语言规范我确实包含了它们,但仍然向我显示了相同的错误。还有其他想法吗,没名字的马?解决了!非常感谢你,没有名字的马:-)解决了!非常感谢,没有名字的马:-)