PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

FEHLER:Berechtigung für Relation Tabellenname auf Postgres verweigert, während ein SELECT als schreibgeschützter Benutzer versucht wird

Hier ist die kürzlich aktualisierte Komplettlösung für PostgreSQL 9+.

CREATE USER readonly  WITH ENCRYPTED PASSWORD 'readonly';
GRANT USAGE ON SCHEMA public to readonly;
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT SELECT ON TABLES TO readonly;

-- repeat code below for each database:

GRANT CONNECT ON DATABASE foo to readonly;
\c foo
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT SELECT ON TABLES TO readonly; --- this grants privileges on new tables generated in new database "foo"
GRANT USAGE ON SCHEMA public to readonly; 
GRANT SELECT ON ALL SEQUENCES IN SCHEMA public TO readonly;
GRANT SELECT ON ALL TABLES IN SCHEMA public TO readonly;

Danke an https://jamie.curle.io/creating-a-read-only-user-in-postgres/ für einige wichtige Aspekte

Wenn jemand kürzeren Code findet und vorzugsweise einen, der dies für alle vorhandenen Datenbanken ausführen kann, extra Lob.