对触发器函数内的表的每一行执行查询

时间:2017-04-28 06:15:45

标签: sql postgresql function cursors

我已经做了以下查询,它本身工作正常,但当我在触发器功能中调用它时,我遇到了问题。

select insert_new_grade('title0', return3_6(0), return3_6(1), return3_6(2), s.code)
FROM "student" as s
where find_st(s.grade)>=5;

insert_new_grade是一个在每次调用时在表中插入新行的函数。

这是触发器:

CREATE OR REPLACE FUNCTION insert_d() 
RETURNS TRIGGER AS $$ 
BEGIN
    select insert_new_grade('title0', return3_6(0), return3_6(1), return3_6(2), s.code)
    FROM "student" as s
    where find_st(s.grade)>=5;

    return new;
END;
$$ LANGUAGE plpgsql; 

这是插入函数:

CREATE OR REPLACE FUNCTION insert_new_grade(title0 character(100), prof0 character(11), prof1 character(11)) 
RETURNS VOID AS $$
BEGIN
    INSERT INTO "d_table"(thes0, title, grade, prof, secProf) 
    VALUES (null, title0, null, prof0, prof1);
END
$$
LANGUAGE 'plpgsql';

有没有办法让查询在触发器函数内工作?如果我使用执行而不是选择插入功能没有结果。我已经阅读了关于游标的内容,但我是postgresql的新手,我不知道该怎么做。有帮助吗?

1 个答案:

答案 0 :(得分:0)

我修改了你的触发功能:

在conlose pgAdmin中检查你的触发器功能,可见raise info文本

CREATE OR REPLACE FUNCTION insert_d() 
RETURNS TRIGGER AS $$ 
declare
    rec record;
BEGIN

    for rec in (select * from student s where find_st(s.grade)>=5) loop

        raise info 'LOOP code = %',rec.code;
        PERFORM insert_new_grade('title0', return3_6(0), return3_6(1), return3_6(2), rec.code);

    end loop;

    return new;
END;
$$ LANGUAGE plpgsql;