Re: Postgresql partitioning

From: Erik Jones <erik(at)myemma(dot)com>
To: Ram Ravichandran <ramkaka(at)gmail(dot)com>
Cc: pgsql-general General <pgsql-general(at)postgresql(dot)org>
Subject: Re: Postgresql partitioning
Date: 2008-03-22 00:59:55
Message-ID: 6F80D318-19DC-41BD-A6B1-845EEF13808A@myemma.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-general

On Mar 21, 2008, at 7:15 PM, Ram Ravichandran wrote:

> Hey,
>
> Suppose I have a table with the following fields:
>
> CREATE TABLE distributors (
> id DECIMAL(3) PRIMARY KEY,
> name VARCHAR(40),
> status INTEGER
> );
>
> I would ike to partition this table based on status which can be
> [0,1,2,3,4].
>
> I was wondering if the records can change their status. i.e. If I did
> UPDATE distributors SET status = 4 WHERE id = 231122;
>
> would POSTGRESQL automatically change the record from the current
> partition (say partition where status = 3) to the partition where
> status = 4?

No. Assuming you have CHECK constraints on you partition tables and
constraint_exclusion=on postgres will emit an error on an update like
that.

> Or would I have to explicitly delete it from one partition table, and
> reinsert it in the other?

Yes. Also, note that this can't be done in an ON UPDATE trigger as
CHECK constraints are checked before any triggers are run.

Erik Jones

DBA | Emma®
erik(at)myemma(dot)com
800.595.4401 or 615.292.5888
615.292.0777 (fax)

Emma helps organizations everywhere communicate & market in style.
Visit us online at http://www.myemma.com

In response to

Responses

Browse pgsql-general by date

  From Date Subject
Next Message Postgres User 2008-03-22 01:42:13 Trigger transactions
Previous Message Ram Ravichandran 2008-03-22 00:15:56 Postgresql partitioning