Re: Creating schema best practices

From: "Babay Adi, Hava" <hava(dot)babay(at)hp(dot)com>
To: Craig James <cjames(at)emolecules(dot)com>
Cc: "pgsql-admin(at)postgresql(dot)org" <pgsql-admin(at)postgresql(dot)org>
Subject: Re: Creating schema best practices
Date: 2012-10-03 17:58:55
Message-ID: C6B1B26CA32AC64F8274F7ACE29D61732F56EA8C@G4W3297.americas.hpqcorp.net
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-admin

Thanks Craig for the useful information.

On the same regard – Some of the mentioned modules in the mentioned application use a set of tables which is logically separate (there are no join statements with tables of other modules). What are the pros\cons of using a separate database instead of a separate schema for maintaining such tables?

I understand that resources are shared among multiple databases on the same cluster, so in terms of performance, are there resources that are dedicated for each database and would benefit performance?

I’d appreciate a best practice also regarding to using database vs schema.

Hava

From: Craig James [mailto:cjames(at)emolecules(dot)com]
Sent: יום ד 03 אוקטובר 2012 19:00
To: Babay Adi, Hava
Cc: pgsql-admin(at)postgresql(dot)org
Subject: Re: [ADMIN] Creating schema best practices

On Tue, Oct 2, 2012 at 11:54 AM, Babay Adi, Hava <hava(dot)babay(at)hp(dot)com<mailto:hava(dot)babay(at)hp(dot)com>> wrote:
Dear list,

I’m new to PostgreSQL, planning now a migration to PostgreSQL and would appreciate your help.

One aspect of the migration is re-thinking our DB structure.

The application considered contains several modules (let’s say ten), each one uses and manages a small number of tables (maximum 10 tables per module). Today all tables are located on the same DB, which makes management a bit uncomfortable. What comes to mind is grouping each module’s tables on a separate schema. From you experience, is there any performance impact for grouping tables into schemas? In general, what is the best practice for grouping tables in schemas vs. locating several tables (that might be logically separated) into the same schema? Is there any advantage \ disadvantage of using schemas vs naming standards that includes prefix for each module’s tables?

In the considered application there are no name duplications among tables. In addition, there are there are no queries that involve tables managed by different modules. In addition, since all modules are owned by the same application, currently there is no interest in limiting access for tables (it is all or nothing).

Since you have no security needs and no naming conflicts, the answer to your question is that it's purely for your convenience. Schemas are primarily useful for separating namespaces and for security. Separating your modules into schemas will have no impact on performance.

pg_dump and pg_restore have support for single-schema dumps, which might make your backup procedures easier.

If I were in your shoes, I'd use schemas just to make management easier. Renaming all of your tables with a module prefix is a waste of time -- that's what schemas are for.

Craig

In response to

Responses

Browse pgsql-admin by date

  From Date Subject
Next Message Brian Fehrle 2012-10-03 20:01:42 Should data directories match between master and hot standby?
Previous Message Craig James 2012-10-03 17:00:05 Re: Creating schema best practices