Hi Thomas,

thanks for your answer. We decided not to go further with this error,
because soon we will have another product that replaces this one. Because I
want to learn more about this topic, I did the following:

Before I write your code, I tried:
select oid,ctid,relname from pg_class where ctid='(4707,0)';

but it resulted in:
oid | ctid | relname
-----+------+---------
(0 rows)

Isn't there suppose to be a ctid of '(4707,0)'? Or did I misunderstand what
you have written?

Regards,
Deniz

On Mon, Aug 1, 2011 at 1:21 PM, Tomas Vondra <t...@fuzzy.cz> wrote:

> On 1 Srpen 2011, 8:27, Deniz Atak wrote:
> > Deepak, Tom thanks for answering.
> >
> > Tom, we have psql 8.1.18. So you are right, this weird message is because
> > of
> > the old version. I will check with my colleague about the possible
> > reasons.
> > What can I do if there is a messed up table?
>
> First of all, you should find out what caused the mess. This could be
> really difficult as it might be a rare hw or sw glitch. Anyway consider
> upgrading to 8.1.23 if possible.
>
> If you have a fresh backup (i.e. one with all the data in the table), just
> restore it and use it. You may even use just this particular table (just
> move it using COPY).
>
> If you need to recover the data, you'll have to play a bit with it as you
> need to 'skip' all the corrupted blocks. The  query reports block 4707 is
> corrupted - how many blocks does the relation have?
>
> You can skip the blocks using 'ctid' column, which is basically "(block
> id, item id)" so to skip block 4707 you can do this
>
> SELECT * FROM table WHERE (ctid < '(4707,0)'::ctid OR ctid >=
> '(4708,0)'::ctid)
>
> and if fails with another "could not read block" error, put there another
> such condition.
>
> Tomas
>
>
>
>

Reply via email to