sql >> データベース >  >> RDS >> PostgreSQL

エラー:読み取り専用ユーザーとしてSELECTを試行しているときに、Postgresのリレーションテーブル名のアクセス許可が拒否されました

    最近更新されたPostgreSQL9以降の完全なソリューションは次のとおりです。

    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/に感謝します

    誰かがより短いコードを見つけた場合、できれば既存のすべてのデータベースに対してこれを実行できるコードを見つけた場合は、追加の賞賛があります。



    1. PostgreSQL関数の言語sqlと言語plpgsqlの違い

    2. .NET用のMySQLコネクタへの参照を追加するにはどうすればよいですか?

    3. nodejs mysqlエラー:接続が失われましたサーバーが接続を閉じました

    4. MySQLクエリの文字列から数値をどのように抽出しますか?