在PostgreSQL中查看有哪些用户的三种方法

 更新时间:2025年09月10日 10:03:26   作者:IT 小阿姨(数据库)  
本文主要介绍了PostgreSQL查看用户(角色)的三种方法:SQL查询系统表(pg_roles/pg_user)、元命令(\du)及pg_shadow视图,适用于不同场景,如日常管理或脚本处理,并有详细的代码示例供大家参考,需要的朋友可以参考下

在 PostgreSQL 中查看用户(在 PostgreSQL 中,用户和角色是同一个概念,ROLE)主要有以下几种方法。

方法一:使用 SQL 命令查询系统目录(推荐)

这是最常用和最灵活的方法。用户信息主要存储在 pg_catalog.pg_roles 系统目录中。

1. 查看所有用户/角色(基本信息)

SELECT rolname AS username, 
       rolsuper AS is_superuser,
       rolcanlogin AS can_login,
       rolcreatedb AS can_create_db,
       rolcreaterole AS can_create_roles,
       rolreplication AS can_do_replication
FROM pg_roles
ORDER BY rolname;

字段解释:

  • rolname: 用户名。
  • rolsuper: 是否是超级用户(t 表示是,f 表示否)。
  • rolcanlogin: 是否有登录权限(即能否作为客户端连接数据库)。具有登录权限的角色才通常被称为“用户”
  • rolcreatedb: 是否有创建数据库的权限。
  • rolcreaterole: 是否有创建其他角色的权限。
  • rolreplication: 是否有流复制的权限。

2. 仅查看具有登录权限的用户(常用)

我们通常更关心能登录数据库的用户。

SELECT usename AS username, 
       usesuper AS is_superuser,
       usecreatedb AS can_create_db,
       usecreaterole AS can_create_roles,
       usesysid AS user_id
FROM pg_user
ORDER BY usename;

pg_userpg_roles 的一个便于查看的视图,它默认只显示具有登录权限的角色。

3. 查看更详细的信息(包括权限、属性等)

SELECT * FROM pg_roles WHERE rolcanlogin = true ORDER BY rolname;

这会列出所有能登录的角色的所有属性,包括账户有效期、连接限制等。

方法二:使用元命令(在 psql 命令行工具中)

如果你正在使用 PostgreSQL 的交互式命令行工具 psql,可以使用快捷的元命令(以反斜杠 \ 开头的命令)。

1. 列出所有角色/用户

\du

或者更详细的版本:

\du+

\du\df 用于函数,\dt 用于表一样,是用于用户的元命令。

2. 列出所有用户(等同于 SELECT * FROM pg_user;)

\dg

在 PostgreSQL 中,\du\dg 是等价的,都可以用来列出角色。

方法三:查看用户属性(如密码有效期、连接限制)

如果你想查看用户更具体的属性配置,可以查询 pg_shadow 系统目录。注意:通常只有超级用户才能查看此视图,因为它包含密码哈希(以md5SCRAM形式加密存储)。

SELECT usename AS username,
       passwd AS password_hash, -- 敏感信息,通常以md5或SCRAM开头
       valuntil AS password_expires_at,
       useconfig AS session_defaults
FROM pg_shadow
WHERE usename = 'your_username'; -- 可以指定要查看的用户名

字段解释:

  • passwd: 加密后的密码。如果是 ********,则表示密码已被加密,无法直接查看明文。
  • valuntil: 密码失效时间(账户有效期)。
  • useconfig: 该用户会话的默认运行时配置(例如,{search_path=myschema, work_mem=16MB})。

示例输出解读

执行 \du 后,你可能会看到如下结果:

                                          List of roles
 Role name |                         Attributes                         | Member of
-----------+------------------------------------------------------------+-----------
 admin     | Superuser, Create role, Create DB, Replication, Bypass RLS | {}
 app_user  | Create DB                                                  | {readonly_group}
 bob       | Password valid until 2024-12-31                            | {}
 readonly  | Cannot login                                               | {}
  • admin: 这是一个超级用户,拥有所有最高权限。
  • app_user: 这是一个普通用户,拥有创建数据库的权限,并且是 readonly_group 角色的成员。
  • bob: 这是一个普通用户,他的密码将在 2024 年底失效。
  • readonly: 这是一个角色Cannot login),不能直接登录,通常被授予其他用户以实现权限分组。

总结

你的需求使用的命令(SQL)使用的元命令(psql 中)
快速查看所有用户及其主要权限SELECT * FROM pg_user;\du 或 \dg
查看所有角色(包括不能登录的)SELECT rolname, rolcanlogin FROM pg_roles;\du
查看更详细的角色属性SELECT * FROM pg_roles;\du+
查看用户的密码和有效期(需超级用户)SELECT * FROM pg_shadow;无直接元命令

对于日常管理,最常用的是 \du 元命令,因为它简单快捷。在脚本或需要程序化处理时,则使用 SELECT ... FROM pg_rolespg_user 的 SQL 查询方式。

到此这篇关于在PostgreSQL中查看有哪些用户的三种方法的文章就介绍到这了,更多相关PostgreSQL查看有哪些用户内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • PostgreSQL对比Mysql分析

    PostgreSQL对比Mysql分析

    PostgreSQL功能完备、标准严格,适配复杂场景与数据分析,MySQL简单高效、高并发优势明显,适合读密集型应用,选择应基于业务需求与团队技术栈,无绝对优劣,对PostgreSQL对比Mysql分析相关知识,感兴趣的朋友一起看看吧
    2025-07-07
  • PostgreSQL入门简介

    PostgreSQL入门简介

    PostgreSQL是一个免费的对象-关系型数据库服务器(ORDBMS),遵循灵活的开源协议BSD。这篇文章主要介绍了PostgreSQL入门简介,需要的朋友可以参考下
    2020-12-12
  • PostgreSql 导入导出sql文件格式的表数据实例

    PostgreSql 导入导出sql文件格式的表数据实例

    这篇文章主要介绍了PostgreSql 导入导出sql文件格式的表数据实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • postgresql 获取两个时间类型小时差值案例

    postgresql 获取两个时间类型小时差值案例

    这篇文章主要介绍了postgresql 获取两个时间类型小时差值案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • PostgreSQL数据库管理系统快速入门

    PostgreSQL数据库管理系统快速入门

    这篇文章主要介绍了PostgreSQL数据库快速入门,PostgreSQL是一个功能强大的开源对象关系型数据库系统,他使用和扩展了SQL语言,并结合了许多安全存储和扩展最复杂数据工作负载的功能,需要的朋友可以参考下
    2023-07-07
  • postgresql json取值慢的原因分析

    postgresql json取值慢的原因分析

    这篇文章主要介绍了postgresql json取值为何这么慢,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06
  • PostgreSQL时间线(timeline)和History File的用法

    PostgreSQL时间线(timeline)和History File的用法

    这篇文章主要介绍了PostgreSQL时间线(timeline)和History File的用法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • PostgreSQL常用优化技巧示例介绍

    PostgreSQL常用优化技巧示例介绍

    PostgreSQL的SQL优化技巧其实和大多数使用CBO优化器的数据库类似,因此一些常用的SQL优化改写技巧在PostgreSQL也是能够使用的。当然也会有一些不同的地方,今天我们来看看一些在PostgreSQL常用的SQL优化改写技巧
    2022-09-09
  • PostgreSQL 默认隔离级别的设置

    PostgreSQL 默认隔离级别的设置

    PostgreSQL的默认事务隔离级别是读已提交,这是其事务处理系统的基础行为模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-06-06
  • postgreSQL中的row_number() 与distinct用法说明

    postgreSQL中的row_number() 与distinct用法说明

    这篇文章主要介绍了postgreSQL中的row_number() 与distinct用法说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01

最新评论