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

本文涉及的产品
云原生数据库 PolarDB MySQL 版,通用型 2核8GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
简介: 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数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
打赏
0
12
12
1
183
分享
相关文章
【赵渝强老师】PostgreSQL的段、区和块
PostgreSQL的逻辑存储结构包括数据库集群、数据库、表空间、段、区、块等,以及表、索引、视图等数据库对象。每个对象有唯一的oid标识符,存储于系统目录表中。段、区、块是数据存储的基本单元,其中块是I/O操作的最小单位,默认大小为8KB。通过合理配置这些结构,可以优化数据库性能。
175 60
【赵渝强老师】PostgreSQL的段、区和块
【赵渝强老师】PostgreSQL的服务器日志文件
本文介绍了PostgreSQL数据库的物理存储结构,重点讨论了服务器日志文件。通过`pg_ctl`命令启动PostgreSQL实例时,使用`-l`参数指定日志文件位置,记录数据库启动、运行及关闭过程中的关键信息。附有相关视频讲解和日志文件示例。
177 0
【赵渝强老师】PostgreSQL的逻辑存储结构
PostgreSQL的逻辑存储结构包括数据库集群、数据库、表空间、段、区、块等。每个对象都有唯一的对象标识符OID,并存储于相应的系统目录表中。集群由单个服务器实例管理,包含多个数据库、用户及对象。表空间是数据库的逻辑存储单元,用于组织逻辑相关的数据结构。段是分配给表、索引等逻辑结构的空间集合,区是段的基本组成单位,而块则是最小的逻辑存储单位。
138 2
【赵渝强老师】PostgreSQL的逻辑存储结构
【赵渝强老师】PostgreSQL的数据库
PostgreSQL的逻辑存储结构涵盖数据库集群、数据库、表、索引、视图等对象,每个对象有唯一的oid标识。数据库集群包含多个数据库,每个数据库又包含多个模式,模式内含表、函数等。通过特定SQL命令可查看和管理这些数据库对象。
【赵渝强老师】PostgreSQL的模板数据库
在PostgreSQL中,创建新数据库时,默认通过拷贝`template1`实现。`template1`包含标准系统对象,可自定义以影响新数据库内容;而`template0`是纯净模板,仅含预定义对象且不应修改。视频讲解和代码示例展示了如何查看现有数据库信息及标识字段的作用。 ![图示](https://ucc.alicdn.com/pic/developer-ecology/yub6x2mlkqwck_398ed06397a44c2d9bfbb5ae5c90bbc0.png) [视频链接](https://www.bilibili.com/video/BV1szyfY4EQn)
【赵渝强老师】PostgreSQL的模板数据库
【赵渝强老师】PostgreSQL的参数文件
PostgreSQL数据库的四个主要参数文件包括:`postgresql.conf`(主要配置文件)、`pg_hba.conf`(访问控制文件)、`pg_ident.conf`(用户映射文件)和`postgresql.auto.conf`(自动保存修改后的参数)。视频讲解和详细说明帮助理解各文件的作用。
193 19
【赵渝强老师】PostgreSQL中的模式
在PostgreSQL中,所有数据库对象均隶属于模式,包括表、索引、视图等,每个对象有唯一的oid标识。创建数据库时,默认生成名为“public”的Schema。用户可自定义模式,如通过SQL语句创建名为demo的模式及其下的表。与Oracle不同,PostgreSQL中用户和模式不是一一对应关系。
148 12
【赵渝强老师】PostgreSQL中的模式
【赵渝强老师】PostgreSQL的控制文件
本文介绍了PostgreSQL数据库的物理存储结构,重点解析了控制文件,包括其重要性及如何通过`pg_controldata`命令查看控制文件内容。控制文件记录了数据库运行的关键信息,如数据库状态、WAL位置等。
183 14
【赵渝强老师】PostgreSQL的WAL预写日志文件
PostgreSQL数据库的物理存储结构包含多种文件,其中WAL(预写日志)用于确保数据完整性和高效恢复。WAL机制允许在不频繁刷新数据至磁盘的情况下,通过先写日志再改数据的方式,减少I/O操作,提高性能。每个WAL文件默认大小为16MB,位于pg_wal目录下,支持手动和自动切换。WAL不仅有助于数据恢复,还能显著降低I/O成本。
173 4
【赵渝强老师】PostgreSQL的运行日志文件
PostgreSQL的物理存储结构包括数据文件、日志文件等。运行日志默认未开启,需配置`postgresql.conf`文件中的相关参数如`log_destination`、`log_directory`等,以记录数据库状态、错误信息等。示例配置中启用了CSV格式日志,便于管理和分析。通过创建表操作,可查看生成的日志文件,了解具体日志内容。
146 3

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等