On Monday, February 17, 2025, Ayush Vatsa <
ayushvatsa1810@gmail.com> wrote:
postgres=# CREATE ROLE alpha;
CREATE ROLE
postgres=# GRANT SELECT ON pg_class TO alpha;
This is pointless, everyone (i.e. the PUBLIC pseudo-role) can already read pg_class.
1. Can a role have access rights to a table without having access to its index?
Roles don’t directly interact with indexes in PostgreSQL so this doesn’t even make sense. But if you need a yes/no answer, then yes.
It fails because AFAICS there is no way for it to work on an index, only tables.
David J.