postgresql - 循环不能正常工作

时间:2013-11-04 12:01:34

标签: postgresql loops record

我写了一些函数来更新或插入日志表中的一些信息。 每个查询应该返回大约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;

1 个答案:

答案 0 :(得分:0)

将RETURN语句移动到函数末尾。你的函数必须有一个RETURN语句,但当它被命中时它会退出(对于set-returns函数你使用RETURN NEXT但这里不适用)。