0

我创建了简单的触发器:

CREATE OR REPLACE FUNCTION emplacement_libre() RETURNS TRIGGER AS $BODY$


DECLARE

i int;
curseur CURSOR FOR 
    SELECT COUNT(*) FROM beta2.astres a
    INNER JOIN beta2.planetes p ON a.id = p.astre_id 
    WHERE a.galaxie = NEW.galaxie AND
    a.ss = NEW.ss AND
    a.position = NEW.position;

BEGIN

OPEN curseur;   

LOOP
    FETCH curseur INTO i;

    IF i>0 THEN
    RAISE EXCEPTION 'la planète est déjà occupée';
    END IF;

    EXIT WHEN NOT FOUND;

END LOOP;

CLOSE curseur;

RETURN NEW;

END;


$BODY$ LANGUAGE plpgsql;


CREATE TRIGGER emplacement_libre
  BEFORE INSERT OR UPDATE ON beta2.astres
  FOR EACH ROW EXECUTE PROCEDURE emplacement_libre();

在 PostgreSQL 文档中,它是关于触发器的名称的:

赋予新触发器的名称。这必须与同一表的任何其他触发器的名称不同。该名称不能是模式限定的 - 触发器继承其 table 的模式。对于约束触发器,这也是使用 SET CONSTRAINTS 修改触发器行为时使用的名称。

所以我希望我的触发器能够获取模式beta2,因为我在CREATE TRIGGER请求中使用了它,但事实并非如此,我的触发器是在默认public模式中创建的......为什么?

4

1 回答 1

0

我认为混淆在于触发器存在的架构与触发器search_path的架构,即您调用的函数的架构。

触发器存储在与表相同的架构中。但是,该过程的搜索路径是在创建时根据您当前的search_path设置处理的。因此,如果您想调用特定模式中的函数,您可能希望通过模式限定名称进行调用。

于 2013-04-19T14:23:45.053 回答