【赵渝强老师】使用PostgreSQL客户端工具

简介: PostgreSQL数据库服务器安装配置完成后,用户可以使用客户端工具连接并操作数据库。本文重点介绍两款常用的PostgreSQL客户端工具:命令行客户端psql和图形化客户端pgAdmin。**psql**是PostgreSQL自带的命令行工具,支持交互式和非交互式模式。交互式模式下,用户可以直接输入SQL命令进行操作;非交互式模式则通过执行脚本文件来完成任务。**pgAdmin**是一款功能全面的图形化管理工具,支持Linux、Windows和Mac OS X系统。通过这两种工具,用户可以高效地管理和操作PostgreSQL数据库。

副本_副本_副本_副本_副本_副本_副本_副本_副本_副本_副本_副本_Oracle-课程封面__2025-03-09+10_48_01.png

在PostgreSQL数据库服务器端安装配置完成以后,便可以使用客户端工具连接到服务器端进行数据库操作了。PostgreSQL支持多种客户端的连接,这里重点介绍psql和pgAdmin这两款PostgreSQL客户端工具的使用方法。


视频讲解如下:


一、命令行客户端psql


psql是PostgreSQL自带的命令行客户端工具。它能够交互式地键入查询,把它们发送给PostgreSQL,并且查看查询结果;或者输入可以来自于一个文件或者命令行参数。此外,psql还提供一些元命令和多种类似shell的特性来编写脚本和实现自动化任务提供便利。因此从功能上看,psql等同于Oracle中的sqlplus。执行该命令连接数据库时, 默认的用户和数据库是postgres。psql的命令格式如下:

psql -h <hostname or ip> -p <端口> [数据库名称] [用户名称]


通过下面的命令可以查看psql的帮助信息:

[postgres@mydb pgsql]$ bin/psql --help
# 输出的信息如下:
psql is the PostgreSQL interactive terminal.
Usage:
  psql [OPTION]... [DBNAME [USERNAME]]
....
Connection options:
  -h, --host=HOSTNAME      database server host or socket directory 
(default: "local socket")
  -p, --port=PORT           database server port (default: "5432")
  -U, --username=USERNAME  database user name (default: "postgres")
  -w, --no-password         never prompt for password
  -W, --password             force password prompt 
(should happen automatically)


psql的两种操作模式:交互式模式和非交互式模式,下面分别进行介绍。


1.1  psql的交互式模式


直接在操作系统的命令行界面上键入bin/psql并回车,从操作系统提示符切换到psql提示符后就表示已经进入了psql 的交互模式界面,就可以执行命令了。在psql的交互式模式下,输入的命令以分号作为命令结束标记。


视频讲解如下:


下表说明了psql提供的常用命令。

image.png


下面创建一个测试用的数据库scott,该数据库中包含两张表,即:员工表(emp)和部门表(dept)。


(1)创建scott数据库。

mydemodb=# create database scott;
mydemodb=# \c scott


(2)创建员工表和部门表。

scott=# create table dept
     (deptno int primary key,
     dname varchar(10),
     loc varchar(10)
     );
scott=# create table emp 
      (empno int primary key,
      ename varchar(10),
      job varchar(10),
      mgr int,
      hiredate varchar(10),
      sal int,
      comm int,
      deptno int,
      foreign key(deptno) references dept(deptno));


(3)在PostgreSQL的命令提示符下往部门表和员工表中插入数据。

-- 插入部门表数据
scott=# insert into dept values(10,'ACCOUNTING','NEW YORK');
scott=# insert into dept values(20,'RESEARCH','DALLAS');
scott=# insert into dept values(30,'SALES','CHICAGO');
scott=# insert into dept values(40,'OPERATIONS','BOSTON');
-- 插入员工表数据
scott=# insert into emp values (7369,'SMITH','CLERK',7902,'1980/12/17',800,null,20);
scott=# insert into emp values (7499,'ALLEN','SALESMAN',7698,'1981/2/20',1600,300,30);
scott=# insert into emp values (7521,'WARD','SALESMAN',7698,'1981/2/22',1250,500,30);
scott=# insert into emp values (7566,'JONES','MANAGER',7839,'1981/4/2',2975,null,20);
scott=# insert into emp values (7654,'MARTIN','SALESMAN',7698,'1981/9/28',1250,1400,30);
scott=# insert into emp values (7698,'BLAKE','MANAGER',7839,'1981/5/1',2850,null,30);
scott=# insert into emp values (7782,'CLARK','MANAGER',7839,'1981/6/9',2450,null,10);
scott=# insert into emp values (7788,'SCOTT','ANALYST',7566,'1987/4/19',3000,null,20);
scott=# insert into emp values (7839,'KING','PRESIDENT',-1,'1981/11/17',5000,null,10);
scott=# insert into emp values (7844,'TURNER','SALESMAN',7698,'1981/9/8',1500,null,30);
scott=# insert into emp values (7876,'ADAMS','CLERK',7788,'1987/5/23',1100,null,20);
scott=# insert into emp values (7900,'JAMES','CLERK',7698,'1981/12/3',950,null,30);
scott=# insert into emp values (7902,'FORD','ANALYST',7566,'1981/12/3',3000,null,20);
scott=# insert into emp values (7934,'MILLER','CLERK',7782,'1982/1/23',1300,null,10);


1.2  psql的非交互式模式


要在非交互模式下使用psql,需要从操作系统的命令提示符执行psql命令,并给其传送一个脚本文件。psql的非交互模式是指在调用psql时直接以选项的形式指定要执行的脚本,脚本中可以含有任意数量的SQL和psql语句,然后psql会自动执行此脚本的内容,期间无需与用户进行交互,这就是非交互模式的本意。要在非交互模式下执行脚本文件,使用-f选项即可。


视频讲解如下:


下面通过一个示例来说明psql的非交互式模式的使用方法。


(1)编辑脚本文件myscript,并输入要执行的SQL和psql语句,如下:

\l
\db
select datname from pg_database;


(2)执行脚本

bin/psql -f myscript
# 输出的结果如下:
                                  List of databases
   Name    |  Owner   | Encoding |   Collate   |    Ctype    |...
-----------+----------+----------+-------------+-------------+...
 mydemodb  | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 |...
 postgres  | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 |...
 template0 | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 |...
 template1 | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 |...
(4 rows)
                         List of tablespaces
    Name    |  Owner   |                   Location                   
------------+----------+-------------------------------------------
 mydemotbs  | postgres | /home/postgres/training/pgsql/data/mydemotbs
 pg_default | postgres | 
 pg_global  | postgres | 
(3 rows)
  datname  
-----------
 postgres
 mydemodb
 template1
 template0
(4 rows)


二、图形化客户端pgAdmin


pgAdmin 4是一款为PostgreSQL设计的可靠和全面的数据库设计和管理软件,它允许用户连接到特定的数据库,创建表和运行各种从简单到复杂的SQL语句。它支持的操作系统包括Linux,Windows,Mac OS X。下图展示了pgAdmin的下载界面。

image.png


这里以Windows版本为例进行介绍。由于pgAdmin 4安装比较简单,这里就不在进行介绍了。pgAdmin 4安装完成后直接启动即可。第一次运行pgAdmin 4的时候,需要设置管理员的密码。如下图所示。

image.png


要使用pgAdmin 4连接PostgreSQL数据库服务器,需要对PostgreSQL数据库服务器端进行相应的配置。下面的步骤展示了整个配置的过程。


(1)修改postgresql.conf文件将参数listen_addresses设置为接收所有客户机地址。

listen_addresses = '*'
# 该参数的默认值是localhost,即:只接受当前主机的客户端请求。


(2)修改配置文件pg_hba.conf,增加下面的参数配置。

host all all 0.0.0.0/0 md5
# 这里设置的“host all all 0.0.0.0/0 md5”表示任何主机均可以以md5加密认证的方式访问任何数据库。


如果不配置该参数会出现下面的错误信息,如下图所示。

image.png



(3)重启PostgreSQL数据库服务器。

bin/pg_ctl -D data/ -l logfile restart


(4)由于在安装PostgreSQL数据库服务器时,没有为用户postgres设置密码。因此这里需要重置一下该用户的密码。使用psql命令行客户端登录PostgreSQL数据库服务器,执行下面的命令设置用户postgres用户的密码。

postgres=# alter user postgres with password 'Welcome_1';


(5)在pgAdmin 4图形工具上,右键点击“Servers”,并选择“Register->Server...”,如下图所示。

image.png


(6)在弹出对话框的“General”选项卡中输入“Name”,如下图所示。

image.png


(7)在“Connection”选项卡中输入“Host name/address”和“Password”,点击“Save”。如下图所示。

image.png


(8)此时便可以成功登录PostgreSQL数据库服务器,如下图所示。

image.png



相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍如何基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
存储 关系型数据库 数据库
【赵渝强老师】PostgreSQL的段、区和块
PostgreSQL的逻辑存储结构包括数据库集群、数据库、表空间、段、区、块等,以及表、索引、视图等数据库对象。每个对象有唯一的oid标识符,存储于系统目录表中。段、区、块是数据存储的基本单元,其中块是I/O操作的最小单位,默认大小为8KB。通过合理配置这些结构,可以优化数据库性能。
280 60
【赵渝强老师】PostgreSQL的段、区和块
|
存储 关系型数据库 数据库
【赵渝强老师】PostgreSQL的服务器日志文件
本文介绍了PostgreSQL数据库的物理存储结构,重点讨论了服务器日志文件。通过`pg_ctl`命令启动PostgreSQL实例时,使用`-l`参数指定日志文件位置,记录数据库启动、运行及关闭过程中的关键信息。附有相关视频讲解和日志文件示例。
396 0
|
7月前
|
安全 Oracle 关系型数据库
【赵渝强老师】基于PostgreSQL的MPP集群:Greenplum
Greenplum是基于PostgreSQL的MPP架构分布式数据库,由Master、Segment和Interconnect组成,支持海量数据并行处理。本文介绍其架构及集群安装配置全过程。
577 1
|
9月前
|
关系型数据库 PostgreSQL
【赵渝强老师】PostgreSQL的并行查询
PostgreSQL的并行查询功能通过多CPU提升查询速度,尤其适用于处理大量数据但返回少量结果的场景。它利用Leader进程、Gather节点和Worker线程协作完成查询任务,显著提高性能。本文详细解析其工作原理及适用场景,并通过实例展示开启与关闭并行查询的性能差异。
299 2
|
8月前
|
存储 关系型数据库 数据库
【赵渝强老师】PostgreSQL数据库的WAL日志与数据写入的过程
PostgreSQL中的WAL(预写日志)是保证数据完整性的关键技术。在数据修改前,系统会先将日志写入WAL,确保宕机时可通过日志恢复数据。它减少了磁盘I/O,提升了性能,并支持手动切换日志文件。WAL文件默认存储在pg_wal目录下,采用16进制命名规则。此外,PostgreSQL提供pg_waldump工具解析日志内容。
736 0
|
11月前
|
Oracle 关系型数据库 数据库
【赵渝强老师】在PostgreSQL中访问Oracle
本文介绍了如何在PostgreSQL中使用oracle_fdw扩展访问Oracle数据库数据。首先需从Oracle官网下载三个Instance Client安装包并解压,设置Oracle环境变量。接着从GitHub下载oracle_fdw扩展,配置pg_config环境变量后编译安装。之后启动PostgreSQL服务器,在数据库中创建oracle_fdw扩展及外部数据库服务,建立用户映射。最后通过创建外部表实现对Oracle数据的访问。文末附有具体操作步骤与示例代码。
864 6
【赵渝强老师】在PostgreSQL中访问Oracle
|
10月前
|
存储 关系型数据库 分布式数据库
【赵渝强老师】基于PostgreSQL的分布式数据库:Citus
Citus 是基于 PostgreSQL 的开源分布式数据库,采用 shared nothing 架构,具备良好的扩展性。它以插件形式集成,部署简单,适用于处理大规模数据和高并发场景。本文介绍了 Citus 的基础概念、安装配置步骤及其在单机环境下的集群搭建方法。
863 2
|
11月前
|
关系型数据库 数据库 PostgreSQL
【赵渝强老师】在PostgreSQL中使用file_fdw访问外部文件系统
本文介绍了PostgreSQL的file_fdw扩展,它支持直接从数据库访问服务器文件系统中的文件,文件格式需为text、csv或binary。内容涵盖从编译安装扩展、配置postgresql.conf参数、重启数据库实例,到创建扩展、外部文件服务及外部表的完整流程,并通过具体示例展示如何查询外部表数据,同时附有视频讲解以帮助理解操作步骤。
350 23
|
11月前
|
关系型数据库 数据库 PostgreSQL
【赵渝强老师】使用postgre_fdw访问外部PostgreSQL
本文介绍了如何使用postgres_fdw扩展让PostgreSQL访问外部远端数据库数据。通过编译安装扩展、修改配置文件、重启数据库、创建扩展及外部服务器对象等步骤,最终实现本地数据库通过外部表访问远程数据。附带视频讲解,详细演示操作流程,并提醒需调整远端PostgreSQL配置以支持远程登录。
260 7
|
12月前
|
SQL 关系型数据库 数据库
【赵渝强老师】创建PostgreSQL的数据库
本文介绍了在PostgreSQL中通过SQL命令“create database”创建数据库的方法。首先查询系统目录pg_database以查看现有数据库集合,然后使用“create database”命令创建新数据库,并了解其在$PDATA/base目录下对应的文件夹生成。最后重新查询数据库集合确认创建结果,附带视频讲解便于理解操作步骤及注意事项。
327 1

推荐镜像

更多