Single Index Tuple Chain (SITC) method - Mailing list pgsql-hackers

From Bruce Momjian
Subject Single Index Tuple Chain (SITC) method
Date
Msg-id 200606281816.k5SIGTR14682@momjian.us
Whole thread Raw
Responses Re: Single Index Tuple Chain (SITC) method  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-hackers
bruce wrote:
> Greg Stark wrote:
> > 
> > Bruce Momjian <bruce@momjian.us> writes:
> > 
> > > PFC wrote:
> > > > 
> > > > > My idea is that if an UPDATE places the new tuple on the same page as
> > > > > the old tuple, it will not create new index entries for any indexes
> > > > > where the key doesn't change.
> > > > 
> > > >     Basically the idea behind preventing index bloat by updates is to have  
> > > > one index tuple point to several actual tuples having the same value.
> > > >     
> > > 
> > > The idea is not to avoid index bloat, but to allow heap reuse, and having
> > > one index entry for multiple versions of an UPDATEd row is merely an
> > > implementation detail.
> > 
> > It sort of sounds like you're describing a whole new index type that stores
> > only the page, not the precise record of any tuple it indexes. If your table
> 
> Background, indexes point to page item pointers, not to actual offsets
> in the page.  This is how vacuum can move around tuples without modifying the
> indexes.  The index points to a page item pointer that is a chain of
> tuples with the same indexed columns.

Here is an overview of the SITC method:
http://momjian.us/cgi-bin/pgsitc

Anyone want to start coding?

--  Bruce Momjian   bruce@momjian.us EnterpriseDB    http://www.enterprisedb.com
 + If your life is a hard drive, Christ can be your backup. +


pgsql-hackers by date:

Previous
From: Tom Lane
Date:
Subject: Re: Instability in TRUNCATE regression test
Next
From: "Jim C. Nasby"
Date:
Subject: Re: Fixed length datatypes. WAS [GENERAL] UUID's as