当table获得一条新记录时自动在另一条记录中创建一条记录

Create a record automatically in another record when table gets a new record

我有两个 table。当一条记录添加到 service table 时,我想在状态为 false 的付款记录中自动创建一条记录。我希望付款看起来像这样,例如,如果已添加服务

它应该像这样自动创建一个付款记录:

id: autoincrement, fk_service 1, price null, payment_date null, status false

在我的网络应用程序中,我将只更新值。

原 tables:

服务

id BIGSERIAL PK,
start_date date not null,
end_date date null,
status VARCHAR(20)

付款

id BIGSERIAL PK,
fk_service BIGSERIAL,
price DECIMAL,
payment_date date,
status BOOLEAN not null,
FOREIGN KEY(fk_service) references service(id)

有人可以指点一下,我该如何实现?

我试过写一个触发器

CREATE FUNCTION insert_payment() RETURNS TRIGGER
AS $insert_payment$
BEGIN
    IF NEW service THEN
        insert into payment(fk_service, status) values (service.id, false) 
    END IF;
END;

我得到 syntax error at or near create line 5 as $BODY$CREATE FUNCTION insert_payment() RETURNS TRIGGER^

您必须将函数“附加”到 at 触发器中,这将是给定 table 上的侦听事件,例如AFTER INSERT 触发器

函数

CREATE OR REPLACE FUNCTION insert_payment() RETURNS TRIGGER AS $$
BEGIN
  INSERT INTO payment(fk_service, status) values (NEW.id, false);
  RETURN NEW;
END;$$ LANGUAGE plpgsql;

触发于 table service

CREATE OR REPLACE TRIGGER on_insert_service AFTER INSERT ON service
FOR EACH ROW EXECUTE PROCEDURE insert_payment();

演示:db<>fiddle