<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="cs">
	<id>http://postgres.cz/index.php?action=history&amp;feed=atom&amp;title=Vytv%C3%A1%C5%99en%C3%AD_do%C4%8Dasn%C3%BDch_tabulek_uvnit%C5%99_funkc%C3%AD</id>
	<title>Vytváření dočasných tabulek uvnitř funkcí - Historie editací</title>
	<link rel="self" type="application/atom+xml" href="http://postgres.cz/index.php?action=history&amp;feed=atom&amp;title=Vytv%C3%A1%C5%99en%C3%AD_do%C4%8Dasn%C3%BDch_tabulek_uvnit%C5%99_funkc%C3%AD"/>
	<link rel="alternate" type="text/html" href="http://postgres.cz/index.php?title=Vytv%C3%A1%C5%99en%C3%AD_do%C4%8Dasn%C3%BDch_tabulek_uvnit%C5%99_funkc%C3%AD&amp;action=history"/>
	<updated>2026-05-12T22:47:07Z</updated>
	<subtitle>Historie editací této stránky</subtitle>
	<generator>MediaWiki 1.43.3</generator>
	<entry>
		<id>http://postgres.cz/index.php?title=Vytv%C3%A1%C5%99en%C3%AD_do%C4%8Dasn%C3%BDch_tabulek_uvnit%C5%99_funkc%C3%AD&amp;diff=440&amp;oldid=prev</id>
		<title>imported&gt;Pavel: Nová stránka: Do verze 8.3 platilo pravidlo, že uvnitř funkcí dočasné tabulky zásadně nerušíme - pokud jsme toto pravidlo porušili, pak při opakovaném provádění dotazu funkce selhal...</title>
		<link rel="alternate" type="text/html" href="http://postgres.cz/index.php?title=Vytv%C3%A1%C5%99en%C3%AD_do%C4%8Dasn%C3%BDch_tabulek_uvnit%C5%99_funkc%C3%AD&amp;diff=440&amp;oldid=prev"/>
		<updated>2008-11-18T14:15:52Z</updated>

		<summary type="html">&lt;p&gt;Nová stránka: Do verze 8.3 platilo pravidlo, že uvnitř funkcí dočasné tabulky zásadně nerušíme - pokud jsme toto pravidlo porušili, pak při opakovaném provádění dotazu funkce selhal...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nová stránka&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Do verze 8.3 platilo pravidlo, že uvnitř funkcí dočasné tabulky zásadně nerušíme - pokud jsme toto pravidlo porušili, pak při opakovaném provádění dotazu funkce selhala - nakešovaný prováděcí plán se odkazoval již na neexistující tabulku. V 8.3 již byla tato chyba opravena. Při dropnutí tabulky se odstraní i všechny prováděcí plány, které se odkazují na odstraněnou tabulku. Tato možnost tu je, nicméně je poměrně náročná, a staré řešení je o dost rychlejší. K mému překvapení je nejrychlejší řešení založené na zachycení výjimky:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
create or replace function test1() &lt;br /&gt;
returns void as $$&lt;br /&gt;
begin &lt;br /&gt;
  drop table if exists omega; &lt;br /&gt;
  create temp table omega(a integer); &lt;br /&gt;
  insert into omega values(10); &lt;br /&gt;
  if exists(select * from omega) then end if; &lt;br /&gt;
end;&lt;br /&gt;
$$ language plpgsql;&lt;br /&gt;
&lt;br /&gt;
create or replace function test2() &lt;br /&gt;
returns void as $$&lt;br /&gt;
begin &lt;br /&gt;
  if exists(select * from pg_class where relname=&amp;#039;omega&amp;#039; and pg_table_is_visible(oid)) then &lt;br /&gt;
    delete from omega; &lt;br /&gt;
  else &lt;br /&gt;
    create temp table omega(a integer); &lt;br /&gt;
  end if; &lt;br /&gt;
  insert into omega values(10); &lt;br /&gt;
  if exists(select * from omega) then end if; &lt;br /&gt;
end;&lt;br /&gt;
$$ language plpgsql;&lt;br /&gt;
&lt;br /&gt;
create or replace function test3() &lt;br /&gt;
returns void as $$&lt;br /&gt;
begin &lt;br /&gt;
  begin &lt;br /&gt;
    delete from omega; &lt;br /&gt;
  exception &lt;br /&gt;
    when others then &lt;br /&gt;
      create temp table omega(a integer); &lt;br /&gt;
  end; &lt;br /&gt;
  insert into omega values(10); &lt;br /&gt;
  if exists(select * from omega) then end if; &lt;br /&gt;
end;&lt;br /&gt;
$$ language plpgsql;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Volání v pgbenchi pro 1000 transakcí, 10 klientů&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Test1:&lt;br /&gt;
transaction type: Custom query&lt;br /&gt;
scaling factor: 1&lt;br /&gt;
query mode: simple&lt;br /&gt;
number of clients: 10&lt;br /&gt;
number of transactions per client: 1000&lt;br /&gt;
number of transactions actually processed: 10000/10000&lt;br /&gt;
tps = 339.780441 (including connections establishing)&lt;br /&gt;
tps = 340.172513 (excluding connections establishing)&lt;br /&gt;
&lt;br /&gt;
Test2:&lt;br /&gt;
scaling factor: 1&lt;br /&gt;
query mode: simple&lt;br /&gt;
number of clients: 10&lt;br /&gt;
number of transactions per client: 1000&lt;br /&gt;
number of transactions actually processed: 10000/10000&lt;br /&gt;
tps = 1891.021562 (including connections establishing)&lt;br /&gt;
tps = 1907.533096 (excluding connections establishing)&lt;br /&gt;
&lt;br /&gt;
Test3:&lt;br /&gt;
transaction type: Custom query&lt;br /&gt;
scaling factor: 1&lt;br /&gt;
query mode: simple&lt;br /&gt;
number of clients: 10&lt;br /&gt;
number of transactions per client: 1000&lt;br /&gt;
number of transactions actually processed: 10000/10000&lt;br /&gt;
tps = 2664.756569 (including connections establishing)&lt;br /&gt;
tps = 2698.289177 (excluding connections establishing&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>imported&gt;Pavel</name></author>
	</entry>
</feed>