From: | "Aaron Bono" <postgresql(at)aranya(dot)com> |
---|---|
To: | "Mark Stosberg" <mark(at)summersault(dot)com> |
Cc: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: Avoiding RI failure with INSERT ... SELECT FROM |
Date: | 2006-07-12 20:06:54 |
Message-ID: | bf05e51c0607121306u7aa28fa3hb4765f167fa229f5@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
On 7/12/06, Mark Stosberg <mark(at)summersault(dot)com> wrote:
>
>
> Hello! I got an unexpected SQL failure last night, and want to see how
> to prevent it in the future. This is with 8.1.3.
>
> I have a couple of insert statements that run in a transaction block,
> initializing rows that will be used the next day:
>
> INSERT into item_hit_log
> SELECT item_id, CURRENT_DATE + CAST('1 day' AS interval), 0
> FROM items where item_state = 'available';
>
> INSERT into item_view_log
> SELECT item_id, CURRENT_DATE + CAST('1 day' AS interval), 0
> FROM items where item_state = 'available';
I would recommend you list your values in your insert statements:
INSERT into item_hit_log (
item_id_fk, ....
)
SELECT ....
That makes it less prone to problems in the future (like if the column
orders change) and makes it easier for others to understand and help you
with.
The "items" table has a few hundred thousand rows in it, so this takes a
> bit a run.
>
> The error we got last night was:
>
> ERROR: insert or update on table "item_hit_log" violates foreign key
> constraint "item_id_fk"
> DETAIL: Key (item_id)=(451226) is not present in table "items".
>
> Re-running the transaction block a few minutes later worked.
>
> What's an alternate design that avoids this possible error?
Does the items table allow deletes? If so, your insert may be attempting to
do an insert for an item_id that was deleted after the select and before the
insert. Don't know if PostgreSQL will prevent that with table locking or
not.
==================================================================
Aaron Bono
Aranya Software Technologies, Inc.
http://www.aranya.com
==================================================================
From | Date | Subject | |
---|---|---|---|
Next Message | Aaron Bono | 2006-07-12 23:28:42 | Logging in Stored Procedure |
Previous Message | Aaron Bono | 2006-07-12 19:37:50 | Re: SQL (Venn diagram type of logic) |