Re: WIP patch: Improve relation size functions such as pg_relation_size() to avoid producing an error when called against a no longer visible relation - Mailing list pgsql-hackers

From Heikki Linnakangas
Subject Re: WIP patch: Improve relation size functions such as pg_relation_size() to avoid producing an error when called against a no longer visible relation
Date
Msg-id 4F17FC2F.2000405@enterprisedb.com
Whole thread Raw
In response to Re: WIP patch: Improve relation size functions such as pg_relation_size() to avoid producing an error when called against a no longer visible relation  (Phil Sorber <phil@omniti.com>)
List pgsql-hackers
On 23.12.2011 02:01, Phil Sorber wrote:
> On Thu, Dec 22, 2011 at 3:19 PM, Robert Haas<robertmhaas@gmail.com>  wrote:
>> On Thu, Dec 22, 2011 at 2:02 PM, Phil Sorber<phil@omniti.com>  wrote:
>>> On Thu, Dec 22, 2011 at 1:33 PM, Tom Lane<tgl@sss.pgh.pa.us>  wrote:
>>>> Robert Haas<robertmhaas@gmail.com>  writes:
>>>>> I'm wondering if we oughta just return NULL and be done with it.
>>>>
>>>> +1.  There are multiple precedents for that sort of response, which we
>>>> introduced exactly so that "SELECT some_function(oid) FROM some_catalog"
>>>> wouldn't fail just because one of the rows had gotten deleted by the
>>>> time the scan got to it.  I don't think it's necessary for the
>>>> relation-size functions to be any smarter.  Indeed, I'd assumed that's
>>>> all that Phil's patch did, since I'd not looked closer till just now.
>>>
>>> Here it is without the checking for recently dead. If it can't open
>>> the relation it simply returns NULL.
>>
>> I think we probably ought to make pg_database_size() and
>> pg_tablespace_size() behave similarly.
>
> Changes added.

Looks good to me, committed. I added a sentence to the docs mentioning 
the new behavior, and also a code comment to explain why returning NULL 
is better than throwing an error.

--   Heikki Linnakangas  EnterpriseDB   http://www.enterprisedb.com


pgsql-hackers by date:

Previous
From: Hitoshi Harada
Date:
Subject: Re: Publish checkpoint timing and sync files summary data to pg_stat_bgwriter
Next
From: Pavel Stehule
Date:
Subject: review:tracking temporary files in pg_stat_database