sql >> Databáze >  >> RDS >> PostgreSQL

Jak vyjmenovat všechny povolené role pro všechny uživatele v PostgreSQL?

Trik je provést rekurzivní dotaz na vztahy systémového katalogu pg_roles a pg_auth_members :

WITH RECURSIVE membership_tree(grpid, userid) AS (
    -- Get all roles and list them as their own group as well
    SELECT pg_roles.oid, pg_roles.oid
    FROM pg_roles
  UNION ALL
    -- Now add all group membership
    SELECT m_1.roleid, t_1.userid
    FROM pg_auth_members m_1, membership_tree t_1
    WHERE m_1.member = t_1.grpid
)
SELECT DISTINCT t.userid, r.rolname AS usrname, t.grpid, m.rolname AS grpname
FROM membership_tree t, pg_roles r, pg_roles m
WHERE t.grpid = m.oid AND t.userid = r.oid
ORDER BY r.rolname, m.rolname;

To poskytuje pohled na všechny uživatele v systému se všemi zděděnými členstvími v rolích. Zabalte to tak, abyste měli tento nástroj vždy po ruce.

Na zdraví, Patricku



  1. Můžete použít automatické zvýšení v MySql, aniž by to byl primární klíč

  2. Podivné chování úplného vnějšího spojení v Oracle – jak by se to dalo vysvětlit?

  3. jak opravit OperationalError:(psycopg2.OperationalError) server neočekávaně ukončil připojení

  4. Typ tabulky v příkladu uložené procedury Oracle