Или вы что-то путаете, или не так описали ситуацию!
В каждой базе есть схема public ->
http://postgresql.ru.net/manual/ddl-schemas.html (5.7.4.)
Она на то и public, что в ней любой пользователь может работать! По вашему скриншоту не понятно, где и куда у пользователей есть доступы? Да, любой пользователь видит все базы. Да, любой пользователь видит все схемы в базах и таблицы. Но, в зависимости от прав, он не сможет посмотреть данные в таблице, к которой у него нет прав.
Я с данной базой только знакомлюсь, но по оракловому опыту могу сказать, что PostgresSQL это не MySQL - не нужно здесь создавать кучу баз! Создайте
одну базу, у базы будет владелец.
Далее пользуйтесь схемами! Создайте пользователя с минимум привилегий и под него создавайте схемы.
Code: Select all
CREATE SCHEMA vasya AUTHORIZATION vasya
Вот фишка, почему пользователь "vasya", созданный без каких либо привилегий (только на логин), видит все схемы (ну это ладно, в оракле пользователь тоже видит все схемы), но так же видит таблицы чужие в ней и атрибуты - я не знаю :) Возможно специфика, возможно что-то нужно капать.