Re: ORDER BY in materialized view example? - Mailing list pgsql-docs

From Tom Lane
Subject Re: ORDER BY in materialized view example?
Date
Msg-id 38996.1637689496@sss.pgh.pa.us
Whole thread Raw
In response to Re: ORDER BY in materialized view example?  (Peter Eisentraut <peter.eisentraut@enterprisedb.com>)
Responses Re: ORDER BY in materialized view example?  ("Jonathan S. Katz" <jkatz@postgresql.org>)
List pgsql-docs
Peter Eisentraut <peter.eisentraut@enterprisedb.com> writes:
> On 23.11.21 07:18, Maciek Sakrejda wrote:
>> An example in the materialized view documentation [1] includes an ORDER 
>> BY clause without a clear reason. Does it help build the index more 
>> efficiently? I suppose it's also sort of like a CLUSTER?

> I agree the ORDER BY is not relevant to the example.  There might be 
> some implementation-dependent advantage to ordering a materialized view, 
> but if there is, it isn't explained in the example.

Yeah.  It would result in the initial contents of the matview being
ordered, but I'm sure we don't wish to guarantee that REFRESH would
preserve that.  I'm on board with just removing the ORDER BY from
that example.

There is also this rather opaque "note" in the REFRESH MATERIALIZED VIEW
man page:

    While the default index for future CLUSTER operations is retained,
    REFRESH MATERIALIZED VIEW does not order the generated rows based on
    this property. If you want the data to be ordered upon generation, you
    must use an ORDER BY clause in the backing query.

I'd rather say something like

    If there is an ORDER BY clause in the matview's defining query,
    the original contents of the matview will be ordered that way;
    but REFRESH MATERIALIZED VIEW does not guarantee to preserve
    that ordering.

            regards, tom lane



pgsql-docs by date:

Previous
From: Peter Eisentraut
Date:
Subject: Re: ORDER BY in materialized view example?
Next
From: "Jonathan S. Katz"
Date:
Subject: Re: ORDER BY in materialized view example?