RE: rules problem - Mailing list pgsql-admin

From Nicolas Huillard
Subject RE: rules problem
Date
Msg-id 01BFB940.D1C41F80@ppp54-cergy.isdnet.net
Whole thread Raw
In response to rules problem  ("Vladimir V. Zolotych" <gsmith@eurocom.od.ua>)
List pgsql-admin
Here is my $0.02 :
* when you create "id SERIAL", Postgres remembers to call function nextval on each insertion,
* the rule's NEW.id item uses the function nextval itself instead of it's result
This explains why the ID's are what you see :
* first of all, you insert the log, calling nextval for the SERIAL (id=1 in the log)
* then you actually insert the data into the colors table (first row has id=2)
* then you insert a second time : first into the log (id=3) then into the actual table (id=4)
This make me think about date constants : 'now' is a constant that have a different value each time you call it. In
yourcase, the rule must use then constant 'nextval', which increments the actual sequence on each call. 
Either this is a bug... or a feature...
I don't see any genral workaround here. Maybe there is another way of retreiving the actual inserted data (other than
NEW.id)

Yours,

Nicolas Huillard
G.H.S
Directeur Technique
Tél : +33 1 43 21 16 66
Fax : +33 1 56 54 02 18
mailto:nhuillard@ghs.fr
http://www.ghs.fr


-----Message d'origine-----
De:    Vladimir V. Zolotych [SMTP:gsmith@eurocom.od.ua]
Date:    lundi 8 mai 2000 18:00
À:    pgsql-admin@postgresql.org
Objet:    [ADMIN] rules problem

Hello all,

Encountered the problem with using RULEs. Cannot log
(e.g. write some info about insertions into sepearate table)
insertions properly. Detailed description (not long or sophisticated)
follows:

I do:

1) CREATE TABLE colors (id SERIAL, color TEXT);

2) Create table for log info:

   CREATE TABLE colors_log (color_id INT4, color TEXT);

3) Create RULE that actually makes log:

   CREATE RULE log_color
   AS ON INSERT
   TO colors
   DO INSERT INTO colors_log VALUES (NEW.id, NEW.color);

4) Make some insertions:

   INSERT INTO colors (color) VALUES ('red');

   The same for 'green', 'blue'.

5) SELECT * FROM colors;

   id|color
   --+-----
    2|red
    4|green
    6|blue

   Here appears the first question:
   why 'id' is 2, 4, 6, not 1,  2, 3?

7) SELECT * FROM colors_log;

   color_id|color
   --------+-----
          1|red
          3|green
          5|blue

   The problem is: the 'id's differ. E.g.,
   In colors_log table the saved 'id' are wrong.

Thanks!



--
Vladimir Zolotych                         gsmith@eurocom.od.ua



pgsql-admin by date:

Previous
From: "Vladimir V. Zolotych"
Date:
Subject: rules problem
Next
From: Peter Eisentraut
Date:
Subject: Re: postgres types