Re: Temporary table weirdness - Mailing list pgsql-sql

From Tom Lane
Subject Re: Temporary table weirdness
Date
Msg-id 23409.1020089557@sss.pgh.pa.us
Whole thread Raw
In response to Temporary table weirdness  (Joseph Barillari <jbarilla@princeton.edu>)
Responses Re: Temporary table weirdness  (Joseph Barillari <jbarilla@princeton.edu>)
Re: Temporary table weirdness  (Bruce Momjian <pgman@candle.pha.pa.us>)
List pgsql-sql
Joseph Barillari <jbarilla@princeton.edu> writes:
> I have a function that creates and destroys temporary tables in the
> course of its work, and have run into trouble if the function
> is executed more than once during a database session. A small
> proof-of-concept is attached below:

> cal=3D> create or replace function frob() returns integer as 'begin create =
> temporary table foo(bar INT); insert into foo (bar) values (1); drop table =
> foo; return 1; end;' language 'plpgsql';

This should be in the FAQ :-(.  Since plpgsql caches query plans, it
will fall over the second time through this code, because the temp table
is no longer the same table (same OID) as it was the first time ---
but the cached plan for the INSERT still has the old OID.

There's a TODO item for plpgsql to detect changes of schema that affect
its cached plans, and drop the cache; but it's not exactly trivial to
do.

In the meantime, you need to use EXECUTE to defeat the plan caching for
every plpgsql query that touches the temp table.  Another answer is to
arrange to create the temp table only once per session, but that's
harder.
        regards, tom lane


pgsql-sql by date:

Previous
From: Bruce Momjian
Date:
Subject: Re: Temporary table weirdness
Next
From: "Josh Berkus"
Date:
Subject: Re: Casting dates