1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
|
\set VERBOSITY 'terse'
set client_min_messages = 'warning';
set datestyle = 'iso, ymd';
create or replace function pgq.insert_event(queue_name text, ev_type text, ev_data text, ev_extra1 text, ev_extra2 text, ev_extra3 text, ev_extra4 text)
returns bigint as $$
begin
raise warning 'insert_event(q=[%], t=[%], d=[%], 1=[%], 2=[%], 3=[%], 4=[%])',
queue_name, ev_type, ev_data, ev_extra1, ev_extra2, ev_extra3, ev_extra4;
return 1;
end;
$$ language plpgsql;
create table trigger_backup (nr int4 primary key, col1 text, stamp date);
create trigger backup_trig_0 after insert or update or delete on trigger_backup
for each row execute procedure pgq.jsontriga('jsontriga', 'backup');
create trigger backup_trig_1 after insert or update or delete on trigger_backup
for each row execute procedure pgq.logutriga('logutriga', 'backup');
-- sqltriga/pl cannot do urlenc
--create trigger backup_trig_2 after insert or update or delete on trigger_backup
--for each row execute procedure pgq.sqltriga('sqltriga', 'backup');
-- test insert
insert into trigger_backup (nr, col1, stamp) values (1, 'text', '1999-02-03');
WARNING: insert_event(q=[jsontriga], t=[{"op":"INSERT","table":["public","trigger_backup"],"pkey":["nr"]}], d=[{"nr":1,"col1":"text","stamp":"1999-02-03"}], 1=[public.trigger_backup], 2=[<NULL>], 3=[<NULL>], 4=[<NULL>])
WARNING: insert_event(q=[logutriga], t=[I:nr], d=[nr=1&col1=text&stamp=1999-02-03], 1=[public.trigger_backup], 2=[<NULL>], 3=[<NULL>], 4=[<NULL>])
update trigger_backup set col1 = 'col1x' where nr=1;
WARNING: insert_event(q=[jsontriga], t=[{"op":"UPDATE","table":["public","trigger_backup"],"pkey":["nr"]}], d=[{"nr":1,"col1":"col1x","stamp":"1999-02-03"}], 1=[public.trigger_backup], 2=[{"nr":1,"col1":"text","stamp":"1999-02-03"}], 3=[<NULL>], 4=[<NULL>])
WARNING: insert_event(q=[logutriga], t=[U:nr], d=[nr=1&col1=col1x&stamp=1999-02-03], 1=[public.trigger_backup], 2=[nr=1&col1=text&stamp=1999-02-03], 3=[<NULL>], 4=[<NULL>])
delete from trigger_backup where nr=1;
WARNING: insert_event(q=[jsontriga], t=[{"op":"DELETE","table":["public","trigger_backup"],"pkey":["nr"]}], d=[{"nr":1,"col1":"col1x","stamp":"1999-02-03"}], 1=[public.trigger_backup], 2=[<NULL>], 3=[<NULL>], 4=[<NULL>])
WARNING: insert_event(q=[logutriga], t=[D:nr], d=[nr=1&col1=col1x&stamp=1999-02-03], 1=[public.trigger_backup], 2=[<NULL>], 3=[<NULL>], 4=[<NULL>])
-- restore
drop table trigger_backup;
\set ECHO none
|