On 12/09/2018 13:25, Christoph Berg wrote: > Re: Peter Eisentraut 2018-09-12 > <0447ec7b-cdb6-7252-7943-88a4664e7...@2ndquadrant.com> >>> Naive idea: make that catalog shared? Collations are system-wide after >>> all. >> >> By the same argument, extensions should be shared, but they are not. > > But extensions put a lot of visible stuff into a database, whereas a > collation is just a line in some table that doesn't get into the way.
How about C functions? They are just a system catalog representation of something that exists on the OS. Anyway, we also want to support application-specific collation definitions, so that users can CREATE COLLATION "my_specific_requirements" and use that that in their application, so global collations wouldn't be appropriate for that. Moreover, the fix for a collation version mismatch is, in the simplest case, to go around and REINDEX everything. Making the collation or collation version global doesn't fix that. It would actually make it harder because you couldn't run ALTER COLLATION REFRESH VERSION until after you have rebuilt all affected objects *in all databases*. -- Peter Eisentraut http://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services