Re: Rules and Command Status - update/insert/delete rule with series of commands in action - Mailing list pgsql-general

From johnlumby@hotmail.com
Subject Re: Rules and Command Status - update/insert/delete rule with series of commands in action
Date
Msg-id PH0PR10MB695991BDE3588B549CE6A4D7A3F32@PH0PR10MB6959.namprd10.prod.outlook.com
Whole thread Raw
In response to Re: Rules and Command Status - update/insert/delete rule with series of commands in action  (Adrian Klaver <adrian.klaver@aklaver.com>)
Responses Re: Rules and Command Status - update/insert/delete rule with series of commands in action
Re: Rules and Command Status - update/insert/delete rule with series of commands in action
Re: Rules and Command Status - update/insert/delete rule with series of commands in action
List pgsql-general


On 5/30/24 4:56 PM, David G. Johnston wrote:

Very little interest exists in working on user-specified rules.  They are practically deprecated.


Ah  -   pity  -   see my last comment to Adrian's



    Any interest in perhaps providing a choice via a configuration parameter?


 If anything is done it would have to be new syntax. 


A much bigger task surely.


On 5/30/24 5:19 PM, Adrian Klaver wrote:

2) Use INSTEAD OF triggers:



Unfortunately the same functionality as in my example with the RULE is not supported for triggers on views :   from the manual

INSTEAD OF triggers may only be defined on views, and only at row level;


A RULE is essentially a statement-level operation which is what I need for this particular case.      A row-level trigger would not work because it cannot "see" the query causing it to be fired,   and also ,  (most importantly) is not fired at all if no rows match the original query,     whereas a RULE is always in effect regardless of which rows are involved. before.      I should add that the RULE I showed in my example is not the only RULE being used on this view  -    there are other conditional RULEs,   and the combined effect is of being able to change the effect of the original statement into a set of new statements,   one of which does what is needed.


And if you are now inclined to say "well,    maybe the application itself is poorly written and should be changed"  -   I would have to agree,    but that is not mine to change.


But I suppose that my next question,   given what you both say about the RULE system being a dead-end,  is whether there is any likelihood of supporting an INSTEAD OF trigger on a view at statement level?   Maybe that stands more chance of going somewhere?



Cheers,     John Lumby


pgsql-general by date:

Previous
From: "Wong, Kam Fook (TR Technology)"
Date:
Subject: How to delete column level Stats/Histogram
Next
From: David Rowley
Date:
Subject: Re: How to delete column level Stats/Histogram