Alvaro Herrera <alvhe...@alvh.no-ip.org> wrote: > On 2025-Feb-26, Antonin Houska wrote: > > > @@ -403,39 +381,38 @@ cluster_rel(Relation OldHeap, Oid indexOid, > > ClusterParams *params) > > * would work in most respects, but the index would only get marked as > > * indisclustered in the current database, leading to unexpected > > behavior > > * if CLUSTER were later invoked in another database. > > + * > > + * REPACK does not set indisclustered. XXX Not sure I understand the > > + * comment above: how can an attribute be set "only in the current > > + * database"? > > */ > > Regarding this XXX comment, what's going on here is this: a CLUSTER > command needs to remember the index that a table is clustered on. We > keep track of this in pg_index.indisclustered. But pg_index is a local > relation, not shared across databases -- so the current CLUSTER command > can effect the update on the current database's pg_index only, not on > other databases. So if the user were to run CLUSTER on one database > specifying an index, then connect to another one and expect CLUSTER > without specifying an index to honor the previously specified index, > that would not work. Naturally this is only a problem for shared > catalogs. Not being able to handle this for shared catalogs is not a > big loss.
Thanks for explanation. The reason I failed to understand this was probably that I tried to imagine something worse. -- Antonin Houska Web: https://www.cybertec-postgresql.com