Re: how to extract the page "address" from the ctid - Mailing list pgsql-general

From Marc Mamin
Subject Re: how to extract the page "address" from the ctid
Date
Msg-id B6F6FD62F2624C4C9916AC0175D56D8828BEBFC1@jenmbs01.ad.intershop.net
Whole thread Raw
In response to Re: how to extract the page "address" from the ctid  (Michael Paquier <michael.paquier@gmail.com>)
List pgsql-general

> -----Original Message-----
> From: Michael Paquier [mailto:michael.paquier@gmail.com]
> Sent: Mittwoch, 1. Juli 2015 07:05
> To: Marc Mamin
> Cc: Postgres General
> Subject: Re: [GENERAL] how to extract the page "address" from the ctid
> 
> On Tue, Jun 30, 2015 at 10:56 PM, Marc Mamin <M.Mamin@intershop.de>
> wrote:
> > while waiting for the new BRIN and improved GIN Indexes :-)
> >
> > I'd like to get a rough feeling, how some column's values are
> distributed on the internal pages.
> > Is there a quicker way to extract the page reference from the ctid?
> 
> Isn't it something that pageinspect can do directly for you? It has
> been extended for brin indexes.
> http://www.postgresql.org/docs/devel/static/pageinspect.html
> --
> Michael

As I understand it, pageinspect allows to get insight in given pages, 
but not to compute overall page distribution analysis of given values.

There is  a function tidsend(tid) that seems to return a row position within a block, but no equivalent to return the
blockposition.
 
I'm fine with my regexp [ substring(ctid::text, '^.([^,]+)') ], but was just wondering if there were a more efficient
wayfor it.
 
This could be a small nice to have e.g. in pageinspect.

regards, 
Marc Mamin

pgsql-general by date:

Previous
From: Andomar
Date:
Subject: Systemd vs logging collector
Next
From: Marc Mamin
Date:
Subject: Re: Systemd vs logging collector