错误:在postgres存储过程中缺少表“raw_data”的FROM子句条目

时间:2017-06-30 14:42:33

标签: postgresql stored-procedures

调用包含以下循环的存储过程时,会出现错误

  

错误:缺少表“raw_data”的FROM子句条目SQL状态:42P01

请注意,raw_data不是表格。

存储过程循环块:

FOR row_data IN SELECT * from temp_alerts_for_today_table

    LOOP

    PERFORM * FROM temp_mails_for_today_table AS temp 
    WHERE temp.mailrecipient = row_data.mailrecipient 
    AND temp.alertconfigurationid = row_data.alertconfigurationid;

    IF(NOT FOUND) THEN

    INSERT INTO temp_mails_for_today_table(mailrecipient, alertconfigurationid, mailsubject, mailcontent, instrumentlist)
    VALUES(row_data.mailrecipient,row_data.alertconfigurationid,row_data.mailsubject,row_data.mailcontent,row_data.instrument);

    ELSE

    SELECT temp.instrumentlist INTO instrument_list 
    FROM temp_mails_for_today_table AS temp 
    WHERE temp.mailrecipient = row_data.mailrecipient 
    AND temp.alertconfigurationid = row_data.alertconfigurationid;

    IF (instrument_list IS NULL) THEN

    UPDATE temp_mails_for_today_table 
    SET instrumentlist = raw_data.instrument 
    WHERE mailrecipient = row_data.mailrecipient 
    AND alertconfigurationid = row_data.alertconfigurationid;

    ELSE

    instrument_list := instrument_list || ',' ||  raw_data.instrument;

    UPDATE temp_mails_for_today_table 
    SET instrumentlist = instrument_list 
    WHERE mailrecipient = row_data.mailrecipient 
    AND alertconfigurationid = row_data.alertconfigurationid;

    END IF;

    END IF;

    END LOOP;

1 个答案:

答案 0 :(得分:0)

raw_data.instrument替换为row_data.instrument