Thread: Rule won't let me NOTIFY, no matter how hard I try

Rule won't let me NOTIFY, no matter how hard I try

From
Jeff Boes
Date:
Here's the setup: I wanted to write a rule that would fire on an update 
to one table, and do an update to another table, followed by a notify. 
My first attempt wasn't acceptable to PG (7.3.4):

create rule "my_rule" as
on update to table_A
where new.col_A != old.col_A
do  (update table_B ...;   notify "my_signal";  );

... because you can't have a "notify" statement in a rule that fires on 
update (only select, update, and delete, I guess).

Second attempt was to "hide" the notify in a function:

create function fn_notify(TEXT) returns VOID as ' execute ''notify " || $1 || "'';
' language 'plpgsql';

Oddly enough, this works IF and ONLY IF the rule "my_rule" fires and the 
internal update statement does not update any rows. If it actually 
updates a row, then I get this error:

WARNING:  plpgsql: ERROR during compile of fn_notify near line 5
ERROR:  syntax error at or near ""

What gives? Must I use a trigger to get around this?


-- 
Jeff Boes                                      vox 269.226.9550 ext 24
Database Engineer                                     fax 269.349.9076
Nexcerpt, Inc.                                 http://www.nexcerpt.com           ...Nexcerpt... Extend your Expertise



Re: Rule won't let me NOTIFY, no matter how hard I try

From
"Luis C. Ferreira"
Date:
El Mar 13 Ene 2004 18:07, Jeff Boes escribió:
>JB: Here's the setup: I wanted to write a rule that would fire on an update
>JB: to one table, and do an update to another table, followed by a notify.
>JB: My first attempt wasn't acceptable to PG (7.3.4):
>JB:
>JB: create rule "my_rule" as
>JB: on update to table_A
>JB: where new.col_A != old.col_A
>JB: do
>JB:    (update table_B ...;
>JB:     notify "my_signal";
>JB:    );
>JB:
>JB: ... because you can't have a "notify" statement in a rule that fires on
>JB: update (only select, update, and delete, I guess).
>JB:
hi,

you have to write to rules

first one (update):

create rule "my_rule" as
on update to table_Awhere new.col_A != old.col_Ado   update table_B ...;

second one (notify):

create rule "my_rule2" as
on update to table_A
notify my_rule;


>JB: Second attempt was to "hide" the notify in a function:
>JB:
>JB: create function fn_notify(TEXT) returns VOID as '
>JB:   execute ''notify " || $1 || "'';
>JB: ' language 'plpgsql';

The correct syntax...

create function fn_notify ( text ) RETURNS void as '
declare       v_signal alias for $1;
begin   execute '' notify "'' || v_signal || ''"'';   return;
end; ' language 'plpgsql';

...and re-write the first rule

create rule "my_rule" as
on update to table_Awhere new.col_A != old.col_Ado   ( update table_B ...;SELECT fn_notify('my_signal'); );

CAVEAT: This rule always returns a tuple:fn_notify
-----------

(1 row)


-- 

---------------------------------------------------------------
Luis Carlos Ferreira                          lcf@tuxedo.com.ar 
Centro de Cómputos            Junin 2957 - Santa Fe - Argentina
Sindicato de Luz y Fuerza              Tel.: (54)(342) 4520-075 
---------------------------------------------------------------

Estas loco?   come vaca!!