Transaction safe Truncate - Mailing list pgsql-hackers

From Rod Taylor
Subject Transaction safe Truncate
Date
Msg-id 1037387475.14810.116.camel@jester
Whole thread Raw
Responses Re: Transaction safe Truncate
List pgsql-hackers
Ok.  Transaction safe truncate is simply transaction safe cluster
without the data copy and a slightly different set of permission checks.

I'd like to split cluster_rel() in cluster.c into 2 functions at line
174.  The permission checks, locking, etc will remain in cluster_rel(). 
The bottom half will be turned into a function called
rebuild_rel(tableOid Oid, indexOid Oid, dataCopy bool).

If dataCopy is set to false, then indexOid may be null -- this will
truncate the table.

Cluster will set dataCopy to true which will maintain current
expectations for cluster.

I'll also move TruncateRelation into cluster.c.

PreCommit_on_commit_actions() -> ONCOMMIT_DELETE_ROWS is the only 
location using heap_truncate(). It may be possible to change this and
remove heap_truncate() altogether.

-- 
Rod Taylor <rbt@rbt.ca>


pgsql-hackers by date:

Previous
From: Jason Tishler
Date:
Subject: Re: [CYGWIN] ipc-daemon
Next
From: Vince Vielhaber
Date:
Subject: Re: Time to move on...