Re: views, queries, and locks - Mailing list pgsql-general

From Tom Lane
Subject Re: views, queries, and locks
Date
Msg-id 27012.1333554185@sss.pgh.pa.us
Whole thread Raw
In response to Re: views, queries, and locks  (Jon Nelson <jnelson+pgsql@jamponi.net>)
Responses Re: views, queries, and locks  (Jon Nelson <jnelson+pgsql@jamponi.net>)
List pgsql-general
Jon Nelson <jnelson+pgsql@jamponi.net> writes:
> On Wed, Apr 4, 2012 at 9:01 AM, Tom Lane <tgl@sss.pgh.pa.us> wrote:
>> Why aren't you using a standard partitioned table, cf
>> http://www.postgresql.org/docs/9.1/static/ddl-partitioning.html

> Because I'm adding "scalar" (constant-value) columns to the view like this:
> SELECT * from tableA, DATE 'date string here' as date_column
> UNION ALL
> SELECT * from tableB, DATE 'date string here' as date_column

> for hundreds or even thousands of tables.

[ yawn... ]  Premature micro-optimization is the root of all evil.
The actual advantage to what you are doing is not scanning irrelevant
partitions, which constraint exclusion handles perfectly fine.  Not
storing the date column is unlikely to be saving anything meaningful.
(How wide are those table rows, anyway?)

More generally, partitioning "hundreds or even thousands" of ways is
costly overkill.  Realistically, do you need to manage your data in
a way that allows you to drop less than perhaps 10% at once?  I think
the usefulness threshold is probably a lot closer to 10% than 0.01%.

            regards, tom lane

pgsql-general by date:

Previous
From: leaf_yxj
Date:
Subject: Questions of the privileges to use the pg_cancel_backend and pg_terminate_backend function. Thanks.
Next
From: Vincas Dargis
Date:
Subject: PostgreSQL 8.4 crash on user defined C language function