Thread: VIEWs and TEMP tables problem
Hi! I found a problem with the views in PostgreSQL if I want to use temporary tables in it. See the next case! CREATE TABLE a(...., code INT4,...); INSERT INTO a(...,code,...) VALUES (...,23,...); CREATE TABLE actual_code(code INT4); If I execute the next query, the result is empty. SELECT * FROM actual_code; CREATE VIEW a_view AS SELECT * FROM a JOIN actual_code AC ON (a.code = AC.code); CREATE TEMP TABLE actual_code AS SELECT 23::INT4 AS code; If I execute the next query, the result contains exactly one row (code: 23). This is perfect. SELECT * FROM actual_code; After it if I compare the the next two queries, there will be differences in the results. 1) SELECT * FROM a JOIN actual_code AC ON (a.code = AC.code); (Result has one row!)2) SELECT * FROM a_view; (Result is empty!) In my opinion this queries should be equivalent with same results. The problem is that the view use the original permanent table, but the 1) query use the temporary actual_code table. I read the temporally table definition in the documentation (http://www.postgresql.org/docs/8.1/interactive/sql-createtable.html) and I concluded it should be working. Is it BUG, or FEATURE? Has anybody got good ideas for solve this problem? This construction came to my mind, because I tried to solve my another question: http://groups.google.co.hu/group/pgsql.performance/browse_thread/thread/c7aec005f4a1f3eb/83fa0053cad33dea Thanks your ideas! Regards, Antal Attila
Antal Attila wrote: > Hi! > > I found a problem with the views in PostgreSQL if I want to use > temporary tables in it. See the next case! [snip] > The problem is that the view use the original permanent table, but the > 1) query use the temporary actual_code table. > I read the temporally table definition in the documentation > (http://www.postgresql.org/docs/8.1/interactive/sql-createtable.html) > and I concluded it should be working. > > Is it BUG, or FEATURE? Has anybody got good ideas for solve this problem? Feature, I'd guess. When the view was built there was no TEMP TABLE. If you do \d a_view you'll see it actually will link to something like "public.a". If it didn't, your view could change depending on your search_path settings and even break. You'll see a similar problem with plpgsql functions. > This construction came to my mind, because I tried to solve my another > question: > http://groups.google.co.hu/group/pgsql.performance/browse_thread/thread/c7aec005f4a1f3eb/83fa0053cad33dea I think you need to explain why you're trying to do this: CREATE VIEW ab_view AS SELECT a.id AS id, a.userid AS userid_a, b.userid AS userid_b, a.col AS col_a, b.col AS col_b FROM aLEFT JOIN b ON (a.id = b.a_id); EXPLAIN ANALYSE SELECT * FROM ab_view WHERE userid_a = 23 AND userid_b = 23 AND col_a LIKE 's%' ORDER BYcol_b LIMIT 10 OFFSET 10; If you want userid_a=userid_b ALWAYS to be the same, just put it in the view. If you sometimes want them different, then you'll have to provide two parameters anyway. It's not clear how you intend to use this. -- Richard Huxton Archonet Ltd
Hi, Antal, Antal Attila wrote: > CREATE VIEW a_view AS SELECT * FROM a JOIN actual_code AC ON (a.code = > AC.code); Here, you bind the View to the permanent table. > CREATE TEMP TABLE actual_code AS SELECT 23::INT4 AS code; And here you create the temp table that will hide the permanent table. > I read the temporally table definition in the documentation > (http://www.postgresql.org/docs/8.1/interactive/sql-createtable.html) > and I concluded it should be working. I would not think so, as it states "unless they are referenced with schema-qualified names". So the permanent table is not removed, only hidden in the default (non-qualified) name space. Views don't look up the tables by name. Views bind to the table via internal ids, and this binding is strong enough to survive even a table rename, still referencing the same table. > Is it BUG, or FEATURE? Has anybody got good ideas for solve this problem? It is a feature. > This construction came to my mind, because I tried to solve my another > question: > http://groups.google.co.hu/group/pgsql.performance/browse_thread/thread/c7aec005f4a1f3eb/83fa0053cad33dea Maybe you try: CREATE VIEW ab_view AS SELECT a.id AS id, a.userid AS userid, a.col AS col_a,b.col AS col_b FROM a LEFT JOIN b ON (a.id = b.a_id AND a.userid=b.userid); EXPLAIN ANALYSE SELECT * FROM ab_view WHERE userid = 23 AND col_a LIKE 's%' ORDER BY col_b LIMIT 10 OFFSET10; HTH, Markus -- Markus Schaber | Logical Tracking&Tracing International AG Dipl. Inf. | Software Development GIS Fight against software patents in EU! www.ffii.org www.nosoftwarepatents.org
Markus Schaber <schabi@logix-tt.com> writes: > Antal Attila wrote: >> Is it BUG, or FEATURE? Has anybody got good ideas for solve this problem? > It is a feature. Right. Note that one possible answer is, after you make the temp table, to create a temp view referencing the temp table (and hiding the permanent view in the same way as the temp table hides the permanent table). regards, tom lane