यहां हाल ही में अपडेट किए गए 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;
कई महत्वपूर्ण पहलुओं के लिए https://jamie.curle.io/creating-a-read-only-user-in-postgres/ को धन्यवाद
अगर किसी को छोटा कोड मिलता है, और अधिमानतः वह जो सभी मौजूदा डेटाबेस के लिए इसे करने में सक्षम है, अतिरिक्त यश।