Postgresql plpgsql:在“或”附近出现语法错误&引用;第66行:结束;

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

当我试图在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_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$
语言规范
我确实包含了它们,但仍然向我显示了相同的错误。还有其他想法吗,没名字的马?解决了!非常感谢你,没有名字的马:-)解决了!非常感谢,没有名字的马:-)