查看pg 用户组_如何查询PostgreSQL中的用户组权限?

So in postgresql I can do something like:

SELECT has_table_privilege('myuser', 'mytable', 'select')

to see whether myuser has select access on mytable. Is there something similar for user groups? Basically, I'd like to be able to submit a query to see if a group has certain privileges on a specified table.

Thanks!

解决方案

Joe's view looks like it was derived from How do I view grants on Redshift. Note this other useful query for finding missing permissions where in this example I want to grant read privs to the select_group to objects that don't have it:

select 'grant select on '||namespace||'.'||item||' to group select_group;' from

(

SELECT

use.usename as subject,

nsp.nspname as namespace,

c.relname as item,

c.relkind as type,

use2.usename as owner,

c.relacl

FROM

pg_user use

cross join pg_class c

left join pg_namespace nsp on (c.relnamespace = nsp.oid)

left join pg_user use2 on (c.relowner = use2.usesysid)

WHERE

c.relowner = use.usesysid

and nsp.nspname NOT IN ('pg_catalog', 'pg_toast', 'information_schema')

and ((array_to_string(relacl, '|') not like '%select_group%' or relacl is null)

or

(array_to_string(relacl, '|') like '%select_group%' and CHARINDEX('r', SPLIT_PART( SPLIT_PART( ARRAY_TO_STRING( RELACL, '|' ), 'select_group', 2 ) , '/', 1 ) ) = 0 )

)

and c.relkind <> 'i'

ORDER BY subject, namespace, item

)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值