From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | Jack Orenstein <jao(at)geophile(dot)com> |
Cc: | pgsql-general(at)postgresql(dot)org |
Subject: | Re: How to use SPI_saveplan |
Date: | 2006-09-10 01:30:39 |
Message-ID: | 29751.1157851839@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-general |
Jack Orenstein <jao(at)geophile(dot)com> writes:
> I'm missing something very basic. If I do this:
> Datum foobar(PG_FUNCTION_ARGS)
> {
> ...
> void* plan = SPI_prepare(...);
> void* saved_plan = SPI_saveplan(plan);
> ...
> }
> then how can I access the saved plan in a later invocation of foobar?
It's up to you to save the pointer somewhere where you can find it again
when you need it. If there's only one interesting plan, use a static
variable. Otherwise, you'll need some sort of data structure to map
from what-you-need to the-plan-that-does-it. You can find examples of
these approaches in the PG sources (from memory, ruleutils.c has some
examples of the former approach while ri_triggers.c does the latter).
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Tom Lane | 2006-09-10 01:34:56 | Re: Is this logical? |
Previous Message | Tom Lane | 2006-09-10 00:57:00 | Re: Is this logical? |