sql >> Databasteknik >  >> RDS >> PostgreSQL

FEL:behörighet nekades för relationstabellnamn på Postgres vid försök med en SELECT som skrivskyddad användare

Här är den kompletta lösningen för PostgreSQL 9+, uppdaterad nyligen.

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;

Tack till https://jamie.curle.io/creating-a-read-only-user-in-postgres/ för flera viktiga aspekter

Om någon hittar kortare kod, och helst en som kan utföra detta för alla befintliga databaser, extra beröm.



  1. EXISTS vs JOIN och användning av EXISTS-klausulen

  2. Fatalt fel:Anrop till odefinierad funktion mysql_connect()

  3. Formatera sysjobhistoria datum och varaktighet Kolumner i SQL Server

  4. SQL-serverlogg, leverans och katastrofåterställning, installation och konfiguration -4