在PostgreSQL环境中,psql命令如何查询并显示所有数据库列表?

Psql查看数据库列表

Psql简介

Psql是PostgreSQL数据库的交互式命令行客户端,支持SQL执行、事务管理及数据库对象操作,查看数据库列表是Psql的基础功能之一,用于确认当前连接环境中的所有数据库,是数据库管理和操作的前提步骤,通过Psql查看数据库列表,可快速了解数据库名称、所有者、状态等核心信息,为后续操作(如选择特定数据库、创建新数据库或删除数据库)提供依据。

在PostgreSQL环境中,psql命令如何查询并显示所有数据库列表?

连接Psql

在使用Psql查看数据库列表前,需先连接到PostgreSQL服务器,基本连接命令格式如下:

psql -U 用户名 -d 数据库名 -h 主机地址 -p 端口
  • -U 用户名:指定连接用户,默认为当前系统用户;
  • -d 数据库名:连接目标数据库(若未指定,默认连接当前用户的主数据库);
  • -h 主机地址:服务器IP或主机名(默认为本地);
  • -p 端口:PostgreSQL默认端口为5432(可省略)。

以用户postgres连接本地默认端口:

psql -U postgres

若未指定数据库,Psql会自动连接当前用户的主数据库(如postgres)。

查看数据库列表的方法

Psql提供了多种命令查看数据库列表,不同命令的输出内容、详细程度存在差异,以下是常用方法及说明:

1 基本命令:l

l是最常用的数据库列表命令,输出包含数据库名、所有者、编码、排序规则等基本信息。

l

输出示例

                         List of databases
   Name    |  Owner   | Encoding |   Collate   |    Ctype    | Access privileges
-----------+----------+----------+-------------+-------------+-----------------------
 postgres  | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 mydb     | admin    | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 template0| postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres
 template1| postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres
(4 rows)

字段说明

  • Name:数据库名称;
  • Owner:数据库所有者;
  • Encoding:数据库编码(如UTF8);
  • Collate/Ctype:排序规则和类型;
  • Access privileges:访问权限(如=c/postgres表示当前用户对数据库的所有者有完全控制权限)。

2 详细命令:l+

l+l的增强版,输出更详细的数据库信息,包括创建时间、大小、表空间等。

l+

输出示例

                         List of databases
   Name    |  Owner   | Encoding |   Collate   |    Ctype    | Encoding for default transaction | Date created | Size | Tablespace | Access privileges
-----------+----------+----------+-------------+-------------+-------------------------------+--------------+------+------------+-----------------------
 postgres  | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | UTF8                           | 2025-01-01   | 8192 | main       | 
 mydb     | admin    | UTF8     | en_US.UTF-8 | en_US.UTF-8 | UTF8                           | 2025-05-15   | 20480| main       | 
 template0| postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | UTF8                           | 2025-01-01   | 8192 | main       | =c/postgres
 template1| postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | UTF8                           | 2025-01-01   | 8192 | main       | =c/postgres
(4 rows)

新增字段

  • Date created:数据库创建时间;
  • Size:数据库大小(以字节为单位);
  • Tablespace:数据库存储的表空间(默认为main);
  • Encoding for default transaction:默认事务的编码(与Encoding一致)。

3 其他命令:list

在某些PostgreSQL版本中,listl+的别名,功能完全相同,若l+不可用,可尝试list

在PostgreSQL环境中,psql命令如何查询并显示所有数据库列表?

list

输出l+一致,此处不再赘述。

4 高级用法:筛选与查询

4.1 筛选特定数据库

若需查看特定数据库(如仅显示用户admin拥有的数据库),可使用-U选项:

l -U admin

输出仅包含admin用户拥有的数据库(如mydb)。

4.2 查看模板数据库

PostgreSQL有template0template1两个模板数据库,用于创建新数据库,若需单独查看模板数据库,可使用-t选项:

l -t template

输出仅包含模板数据库(如template0template1)。

4.3 使用SQL查询

Psql支持执行SQL语句,可通过SELECT查询数据库信息,获取所有非模板数据库的列表:

SELECT datname FROM pg_database WHERE datistemplate = false;

输出

 datname 
 mydb    
(1 row)

若需查看数据库大小(以易读格式),可结合pg_size_pretty()函数:

SELECT datname, pg_size_pretty(pg_database_size(datname)) AS size 
FROM pg_database 
WHERE datistemplate = false;

输出

 datname | size 
----------+------
 mydb    | 20 MB
(1 row)
命令适用场景
l基本列表(数据库名、所有者、编码等)快速查看数据库基本信息
l+详细列表(创建时间、大小、表空间等)需了解数据库详细信息时
list与l+功能相同旧版本或别名使用
l -U 用户名筛选指定用户拥有的数据库权限管理或特定用户操作
l -t 模板名筛选模板数据库模板数据库维护
SQL查询自定义数据库列表需复杂筛选或统计时

常见问题与技巧

1 如何查看当前连接的数据库?

若需确认当前连接的数据库,可通过c 数据库名切换数据库,或使用conninfo命令查看连接信息:

conninfo

输出示例

在PostgreSQL环境中,psql命令如何查询并显示所有数据库列表?

You are connected to database "mydb" as user "admin" via socket "/var/run/postgresql/.s.PGSQL.5432" at port "5432".

执行SQL语句SELECT current_database();也可获取当前数据库名:

SELECT current_database();

输出

 current_database 
 mydb            
(1 row)

2 如何查看数据库的详细信息(如大小、创建时间)?

若需更详细的数据库信息(如大小、创建时间),推荐使用l+命令,其输出已包含核心字段,若需通过SQL查询,可使用以下语句:

SELECT datname, datcreated, pg_database_size(datname) AS size 
FROM pg_database 
WHERE datistemplate = false;

输出

 datname | datcreated | size 
----------+------------+-------
 mydb    | 2025-05-15 | 20 MB
(1 row)

3 权限问题处理

若当前用户没有查看所有数据库的权限(如普通用户仅能查看自己拥有的数据库),l命令会仅输出该用户拥有的数据库,此时需使用超级用户(如postgres)连接:

psql -U postgres

超级用户拥有查看所有数据库的权限,可执行l获取完整列表。

FAQs

如何查看当前连接的数据库?

解答

  • 使用conninfo命令查看连接信息;
  • 执行SQL语句SELECT current_database();获取当前数据库名。

如何查看数据库的详细信息(如大小、创建时间)?

解答

  • 使用l+命令(输出包含创建时间、大小等字段);
  • 执行SQL查询SELECT datname, datcreated, pg_database_size(datname) AS size FROM pg_database WHERE datistemplate = false;获取自定义信息。

通过以上方法,可高效使用Psql查看数据库列表,并掌握相关操作技巧,为PostgreSQL数据库管理提供基础支持。

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/201409.html

(0)
上一篇2025年12月29日 04:49
下一篇 2025年12月29日 04:55

相关推荐

  • 如何选择合适的proxy服务器软件?配置步骤与常见问题全解析

    Proxy服务器软件Proxy服务器软件作为网络通信的关键组件,扮演着“中介”角色,连接客户端与互联网服务器,它通过接收客户端的请求,转发至目标服务器并返回响应,实现IP地址隐藏、访问控制、流量优化等功能,广泛应用于个人隐私保护、企业网络管理、网站加速等领域,本文将系统介绍Proxy服务器软件的定义、分类、功能……

    2025年12月28日
    0370
  • 通为网络官方的虚拟主机产品,其具体名称叫什么?

    核心答案:通为网络虚拟主机的命名逻辑通为网络的虚拟主机产品,通常不拥有一个类似“神舟飞船”或“银河战舰”那样的独立商品名,其官方名称直接、明了,即为“虚拟主机”,在具体的销售和配置页面,您会看到诸如“入门型虚拟主机”、“商务型虚拟主机”、“企业型虚拟主机”乃至“独享型虚拟主机”等描述,这种命名方式的核心逻辑在于……

    2025年10月18日
    0470
  • 如何在服务器上一步步搭建多个网站的虚拟主机?

    在互联网的广阔世界中,将一台物理服务器分割成多个独立的虚拟主机空间,是托管多个网站最经济、最高效的方式之一,这种技术允许个人或企业以较低的成本,在单一服务器上运行多个拥有独立域名、独立内容、甚至独立配置的网站,本文将详细阐述如何在服务器上搭建虚拟主机,从核心概念到具体操作步骤,为您提供一份清晰、全面的指南,理解……

    2025年10月29日
    0560
  • 关于PostgreSQL排行榜,你关心的排名逻辑、应用价值与行业趋势问题有哪些?

    PostgreSQL(简称PG)作为一款开源关系型数据库管理系统,自1986年由Waldemar Korczak开发以来,凭借其卓越的技术特性与活跃的社区生态,在全球数据库市场中占据重要地位,它不仅是全球最大的开源数据库项目之一,更因强大的功能、高可靠性和灵活的扩展性,被广泛应用于金融、医疗、电商、云服务等关键……

    2026年1月2日
    0240

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注