6

我正在尝试使用触发器和序列创建一个自动增量字段(如 SERIAL)。我知道只能在字段上使用序列或序列类型,但我必须使用两种方法(触发器和安全)来解决这个问题

CREATE SEQUENCE AlimentosSequencia;

CREATE OR REPLACE FUNCTION AlimentoFuncion()
  RETURNS "trigger" AS
$BODY$
    BEGIN
      New.id:=nextval('AlimentosSequencia');
      Return NEW;
    END;
$BODY$

LANGUAGE 'plpgsql' VOLATILE;

CREATE TRIGGER AlimentosTrigger
  BEFORE INSERT
  ON alimento
  FOR EACH ROW
  EXECUTE PROCEDURE AlimentoFuncion();

我尝试了这种组合但不起作用,表 alimento 只有两个字段,整数 id(带触发器和序列的自动增量)和 varchar 名称。

有什么建议吗?

谢谢

4

1 回答 1

10

正如其他用户告诉您的那样,您不需要使用触发器。您可以像这样声明表:

CREATE SEQUENCE AlimentosSequencia;

CREATE TABLE alimento (
  id integer NOT NULL DEFAULT nextval('AlimentosSequencia') PRIMARY KEY
 ,name VARCHAR(255));

当您插入新记录时:

INSERT INTO alimento (name) VALUES ('lemon');

另一种可能性是将id字段声明为serial type,它会自动创建序列。

更新: 好的,这是一个练习。那我不明白是什么问题?我已经测试了这段代码:

CREATE SEQUENCE AlimentosSequencia;

CREATE TABLE alimento (
  id integer NOT NULL PRIMARY KEY
 ,name VARCHAR(255));

 CREATE OR REPLACE FUNCTION AlimentoFuncion()
 RETURNS "trigger" AS
 $BODY$
 BEGIN
   New.id:=nextval('AlimentosSequencia');
   Return NEW;
 END;
 $BODY$
 LANGUAGE 'plpgsql' VOLATILE;

 CREATE TRIGGER AlimentosTrigger
 BEFORE INSERT
 ON alimento
 FOR EACH ROW
 EXECUTE PROCEDURE AlimentoFuncion();

 INSERT INTO alimento (name) VALUES ('lemon');

它可以毫无问题地工作。

于 2012-06-22T12:04:45.287 回答