0

我编写了函数来更新或插入日志表中的一些信息。每个查询应该返回大约 100 条记录,但下面的函数总是只更新或插入最后一行。
我应该放在RETURN NEXT前面的东西,END LOOP但它不起作用。

CREATE OR REPLACE FUNCTION plugins.update_log()
  RETURNS void AS
$BODY$
DECLARE
    rec record;
BEGIN
FOR rec IN 
    SELECT     na1_nr::integer,
               CASE WHEN c.record_status_id::integer = 8 THEN c.niezainteresowany_powod::text ELSE ots.name::text END reason
    FROM       temp_id c
    LEFT JOIN  plugins.outbounds_telcom_statuses ots ON (ots.telcom_status_id::integer=c.telcom_status_id::integer AND ots.outbound_id::integer = 33)

    LOOP

        UPDATE  plugins.boss_release_log 
        SET     count = count::integer +1 
        WHERE   na1_nr::integer = rec.na1_nr::integer
        AND     reason::text = rec.reason::text;

        IF found THEN
            RETURN;
        END IF;

        BEGIN
            INSERT INTO plugins.boss_release_log(na1_nr,reason,count) 
            VALUES (rec.na1_nr, rec.reason, 1);
            RETURN;
        EXCEPTION WHEN unique_violation THEN

        END;

    END LOOP;

END;
$BODY$
  LANGUAGE plpgsql VOLATILE
  COST 100;
ALTER FUNCTION plugins.update_log()
  OWNER TO ss0;
4

1 回答 1

0

将 RETURN 语句移到函数的末尾。您的函数中必须有一个 RETURN 语句,但是当它被击中时它会退出(对于设置返回函数,您使用 RETURN NEXT 但这在这里不适用)。

于 2013-12-06T02:53:25.097 回答