Re: Support logical replication of DDLs

From: Marcos Pegoraro <marcos(at)f10(dot)com(dot)br>
To: Zheng Li <zhengli10(at)gmail(dot)com>
Cc: PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org>
Subject: Re: Support logical replication of DDLs
Date: 2022-02-22 12:00:36
Message-ID: CAB-JLwYkc6T4PX1OD3r9Zm-39OVpZ5+Ev4dvLYPkMT2EJEgyEA@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-general pgsql-hackers

Em seg., 21 de fev. de 2022 às 13:13, Zheng Li <zhengli10(at)gmail(dot)com>
escreveu:

>
> 2. Table level
> Allows DDLs on the published tables to be replicated except for
> certain edge cases.
>
> Think how to handle triggers and functions with same name but different
purpose.

Publisher
create function public.audit() returns trigger language plpgsql as $$
begin
new.Audit_User = current_user();
new.Audit_Date_Time = now();
return new;
end;$$
create trigger audit before insert or update on foo for each row execute
procedure public.audit();

Subscriber
create function public.audit() returns trigger language plpgsql as $$
begin
insert into Audit(Audit_Date_Time, Audit_User, Schema_Name, Table_Name,
Audit_Action, Field_Values) values(new.Audit_ts, new.Audit_User,
tg_table_schema, tg_table_name, tg_op, row_to_json(case when tg_op =
'DELETE' then old.* else new.* end));
return null;
end;$$
create trigger audit after insert or update or delete on foo for each row
execute procedure public.audit();

regards,
Marcos

In response to

Browse pgsql-general by date

  From Date Subject
Next Message Allan Jardine 2022-02-22 15:22:41 Full text search - wildcard and a stop word
Previous Message Aleksander Alekseev 2022-02-22 10:05:05 Re: Support logical replication of DDLs

Browse pgsql-hackers by date

  From Date Subject
Next Message osumi.takamichi@fujitsu.com 2022-02-22 12:22:18 RE: Design of pg_stat_subscription_workers vs pgstats
Previous Message Aleksander Alekseev 2022-02-22 10:05:05 Re: Support logical replication of DDLs