"David G. Johnston" <david.g.johns...@gmail.com> writes: > On Tue, Apr 15, 2025 at 11:20 AM Adrian Klaver <adrian.kla...@aklaver.com> > wrote: >> If what you say is true why does initdb lack an option to not create >> them on creating a cluster?
> By creating the initial three databases the system is more usable due to > having established conventions. They are conventional databases, not > system ones. Precisely. For example, the only reason for the "postgres" database to exist is so that there is a reasonable default database for clients to connect to. If we didn't have it we'd need some other convention. (Indeed, we used to not have it, and back then the default client behavior was usually to connect to template1. That led to people creating random junk in template1 and then being surprised when CREATE DATABASE copied it into new databases.) In the end this discussion is about terminology. These three databases are part of the ecosystem and clients generally expect them to be there. But the server doesn't depend on them to function. Does that make them "system" databases? All depends on what you think that means. regards, tom lane