首页 > 解决方案 > 获取正在使用数据库/模式/表的用户列表

问题描述

在我的项目中有一个用例,我想向用户展示有权在 postgresql 中使用该数据库/模式/表的用户。假设我创建了一个数据库员工。所以我想列出正在访问这个数据库的用户。架构和表相同。我试过这个:

SELECT 
    * 
FROM 
    information_schema.tables 
WHERE 
    table_schema not in ('pg_catalog', 'information_schema') AND 
    table_schema not like 'pg_toast%'

但它提供了有关当前用户可以访问的信息。我想要访问正在使用该数据库/表/模式/列的用户的列表。

标签: postgresqlamazon-redshiftpsql

解决方案


您可以使用该功能has_table_privilege()来实现您想要的。

select has_table_privilege('user_name', 'schema.table', 'select');

更多信息在这里

我想您需要成为超级用户才能获得所有结果。下面显示了所有具有权限的用户,不一定是他们是否正在访问这些表。

现在您可以调整查询以将所有用户加入到表列表中 -

SET search_path TO public,
      schema1;

SELECT *, 
       usename,
       has_table_privilege(usename, table_schema||'.'||table_name, 'select') as has_privilege
FROM SVV_TABLES
JOIN PG_USER
ON 1=1
WHERE table_schema = 'schema1';

推荐阅读