postgresql - 如何获取 PostgreSQL 中的行策略列表?

标签 postgresql postgresql-9.5

PostgreSQL 文档描述了如何创建或删除行策略,但没有如何获取现有行策略的列表。 我的目标是能够通过使用 pgAdmin 了解是否存在影响表的行策略以及它们的工作方式。

谢谢!

最佳答案

比目录 View 更有帮助 pg_policypg_policies .您会看到它适用于哪个表,甚至该策略的作用(尽管这似乎被截断了)。

所以只需运行:select * from pg_policies

实际上归结为这个(感谢@jmelesky):

 SELECT n.nspname AS schemaname,
    c.relname AS tablename,
    pol.polname AS policyname,
        CASE
            WHEN pol.polpermissive THEN 'PERMISSIVE'::text
            ELSE 'RESTRICTIVE'::text
        END AS permissive,
        CASE
            WHEN pol.polroles = '{0}'::oid[] THEN string_to_array('public'::text, ''::text)::name[]
            ELSE ARRAY( SELECT pg_authid.rolname
               FROM pg_authid
              WHERE pg_authid.oid = ANY (pol.polroles)
              ORDER BY pg_authid.rolname)
        END AS roles,
        CASE pol.polcmd
            WHEN 'r'::"char" THEN 'SELECT'::text
            WHEN 'a'::"char" THEN 'INSERT'::text
            WHEN 'w'::"char" THEN 'UPDATE'::text
            WHEN 'd'::"char" THEN 'DELETE'::text
            WHEN '*'::"char" THEN 'ALL'::text
            ELSE NULL::text
        END AS cmd,
    pg_get_expr(pol.polqual, pol.polrelid) AS qual,
    pg_get_expr(pol.polwithcheck, pol.polrelid) AS with_check
   FROM pg_policy pol
     JOIN pg_class c ON c.oid = pol.polrelid
     LEFT JOIN pg_namespace n ON n.oid = c.relnamespace;

关于postgresql - 如何获取 PostgreSQL 中的行策略列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38104160/

相关文章:

javascript - 我如何访问这个 javascript 值?

postgresql - 使用窗口函数计算百分位数

sql - INSERT [...] ON CONFLICT 可以用于外键违规吗?

sql - 插入冲突时回滚触发器

postgresql - 使用 Postgres 触发器进行增量原子操作和高并发安全吗?

database - postgresql pg_dump 的输出去哪里

postgresql - Postgres PL/pgSQL,可以声明匿名自定义类型吗?

postgresql - PostgreSQL 中的大小写不敏感

sql - 从非阻塞用户获取帖子

sql - Postgresql 递归返回意外结果