Re: Using Temporary Tables in postgres functions
От | Mario Splivalo |
---|---|
Тема | Re: Using Temporary Tables in postgres functions |
Дата | |
Msg-id | 1169808397.3045.13.camel@localhost.localdomain обсуждение исходный текст |
Ответ на | Re: Using Temporary Tables in postgres functions (Stephan Szabo <sszabo@megazone.bigpanda.com>) |
Список | pgsql-sql |
On Thu, 2007-01-25 at 08:03 -0800, Stephan Szabo wrote: > On Thu, 25 Jan 2007, Mario Splivalo wrote: > > > When I try to use TEMPORARY TABLE within postgres functions (using 'sql' > > as a function language), I can't because postgres can't find that > > temporary table. Consider this example: > > > > CREATE FUNCTION func1() RETURNS SETOF v_messages_full AS $BODY$ > > CREATE TEMPORARY TABLE tmpTbl > > AS > > SELECT > > message_id > > FROM > > cached_messages > > WHERE > > billing_status = 2; > > > > > > UPDATE cached_messages SET billing_status = 1 WHERE message_id IN > > (SELECT message_id FROM tmpTbl); > > > > SELECT > > * > > FROM > > v_messages_full > > WHERE > > message_id IN (SELECT message_id FROM tmpTbl); > > $BODY$ LANGUAGE 'sql' VOLATILE SECURITY DEFINER; > > It seems like the sql function checker is unhappy with the above. Does it > actually work if you turn off the check_function_bodies configuration > variable, create the function and then call it? Yes, when I do 'set check_function_bodies to false;' then I can create the function but I'm unable to execute it: testdb1=# select * from func1(); ERROR: relation "tmptbl" does not exist CONTEXT: SQL function "func1" during startup Bummer. In the end I wrote the function using plpgsql. Now, is there any performance impact on using plpgsql instead of sql in simple scenarios as in func1() example? I guess there should be some, as minimas as it can be, but have no way of actualy knowing that. Mike
В списке pgsql-sql по дате отправления: