sql >> Database teknologi >  >> RDS >> PostgreSQL

FEJL:tilladelse nægtet til relationstabelnavn på Postgres, mens du prøvede en SELECT som skrivebeskyttet bruger

Her er den komplette løsning til PostgreSQL 9+, opdateret for nylig.

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;

Tak til https://jamie.curle.io/creating-a-read-only-user-in-postgres/ for flere vigtige aspekter

Hvis nogen finder en kortere kode, og helst en der er i stand til at udføre dette for alle eksisterende databaser, ekstra ros.



  1. Har PL/SQL-udgange i realtid

  2. RAWTOHEX() Funktion i Oracle

  3. Optimeringstærskler – gruppering og aggregering af data, del 5

  4. ORA-01219:database ikke åben:forespørgsler er kun tilladt på faste tabeller/visninger