PostgreSQL常用命令,启动连接,pg_dump导入导出

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
简介: PostgreSQL常用命令,启动连接,pg_dump导入导出

文章目录

  • 1 PostgreSQL服务启动与停止、连接
  • 2 常用sql命令
  • 3 数据备份与恢复

1 PostgreSQL服务启动与停止、连接

在没有设置环境变量的情况下 需进入pgsql的bin目录

#Windows下启动
#打开“开始”菜单,找到 “PostgreSQL” 文件夹,找到 “pgAdmin” 应用程序,单击该应用程序图标启动PostgreSQL
进入postgresql目录
.\bin\pg_ctl -D data -l logfile start
.\bin\pg_ctl -D data -l logfile stop
.\bin\pg_ctl -D 数据目录 -l /xx/postgresql.log start        #PostgreSQL 的 pg_ctl 命令要求 -l 参数后跟的是一个日志文件的路径,而不是目录。你需要指定一个具体的文件名,例如 D:\SoftwareInstall\PostgreSQL\data\log\postgresql.log。这样,PostgreSQL 就可以在该目录下创建或追加日志文件
注册为本地服务后 可直接通过 net start xx 启动服务
#Linux下启动
su - postgres
/usr/local/pgsql/bin/pg_ctl start -D /usr/local/pgsql/data -l /usr/local/pgsql/logfile

#连接指定服务器上的数据库(-U 用户名)
psql -h IP -p 端口 -U 用户名 -d 数据库名 -W

2 常用sql命令

select version(); #显示版本信息
\l  #列出所有数据库
\c database_name #切换到指定的数据库
#查看当前使用的数据库
select current_database();
\c #显示当前数据库名称和用户
\conninfo #显示客户端的连接信息
\du #显示所有用户
\dn #显示数据库中的schema
\encoding #显示字符集

#创建数据库
creadb database db_name owner 所属用户 encoding UTF8;
drop database db_name;

\d #列出数据库中所有表
\dt #列出数据库中所有表
\d [table_name] #显示指定表的结构
\di #列出数据库中所有 index
\dv #列出数据库中所有 view
drop table tb_name;  #删除一张表
#插入数据
insert into table_name(column1,column2,...) values(value1,value2,..)
alter table [表名] drop column [字段名];  #删除表中的字段

\i testdb.sql #执行sql文件
\x #扩展展示结果信息,相当于MySQL的\G
\o /tmp/test.txt #将下一条sql执行结果导入文件中
\? #所有命令帮助
\h #sql命令帮助
\q #退出连接

3 数据备份与恢复

#  导出数据
#导出数据库结构和数据
pg_dump -h ip -p port -U 用户名 -d your_database -f backup.sql
#导出数据库结构(仅架构)
pg_dump -h ip -p port -U 用户名 -d your_database -s -f schema_dump.sql

#导出单表结构和数据
pg_dump -h ip -p port -U 用户名 -d your_database -t table_name -f backup.sql  #sql中数据为copy方式 
pg_dump -h ip -p port -U 用户名 -d database_name -t table_name --column-inserts -f backup.sql  #sql中数据为insert方式,速度慢,便于导入到非PostgreSQL数据库
pg_dump -h ip -p port -U 用户名 -d database_name -t table_name --column-inserts > backup.sql   #不仅可以使用 -f xx.sql,也可使用 > xx.sql
#只导出表结构,不导出表数据
pg_dump -h ip -p port -U 用户名 -d database_name -t table_name -s -f backup.sql  #-s 参数只导致对象定义模式,不导出数据
#只导出表数据,不导出表结构
pg_dump -h ip -p port -U 用户名 -d database_name -t table_name -a -f backup.sql  #-a 参数只导出表数据,不导出表结构

#导出多个表数据
pg_dump -h ip -p port -U 用户名 -d database_name -t tb_name1 -t tb_name2 -f backup.sql



#  导入数据 执行sql文件
psql -h IP -p port -U 用户名 -W -d db_name < dump/save.sql
psql -h ip -p port -U postgres -d db_name -f xxx.sql

pg_dump 常用参数

  • -h host:指定数据库主机名,或者IP
  • -p port:指定端口号
  • -U user:指定连接使用的用户名
  • -W:按提示输入密码
  • -d, --dbname=DBNAME:指定要导出的数据库名称
  • -a,–data-only:只导出表数据,不导出表结构
  • -s,–schema-only:只导致对象定义模式,不导出数据
  • -t,–table=table,只转存匹配到的表,视图,序列,可以使用多个-t匹配多个表,不指定具体表则导出整个数据库
  • -c,–clean:在导入时清理(删除)数据库,是否生成清理该数据库对象的语句,比如drop table
  • -C,–create,是否输出一条创建数据库语句
  • -f file,–file=file,指定输出文件或目录名,输出到指定文件中
  • -n schema,–schema=schema,只转存匹配schema的模式内容
  • -N schema,–exclude-schema=schema,不转存匹配schema的模式内容
  • -O,–no-owner,不设置导出对象的所有权
  • -T table,–exclude-table=table,不转存匹配到的表。
  • –inserts,使用insert命令形式导出数据,这种方式比默认的copy方式慢很多,但是可用于将数据导入到非PostgreSQL数据库。
  • –-column-inserts,导出的数据有显式列名,以带有列名的 INSERT 命令形式转储数据
  • 数据库名放最后,不指定默认是系统变量PGDATABASE指定的数据库
相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
4月前
|
关系型数据库 Shell C#
PostgreSQL修改最大连接数
在使用PostgreSQL时,可能遇到“too many clients already”错误,这是由于默认最大连接数(100)不足。要增加此数值,需修改`postgresql.conf`中的`max_connections`参数
241 5
|
1月前
|
关系型数据库 数据库 PostgreSQL
深入理解 PostgreSQL 的 JOIN 连接
深入理解 PostgreSQL 的 JOIN 连接
109 4
|
4月前
|
JavaScript 关系型数据库 API
Nest.js 实战 (二):如何使用 Prisma 和连接 PostgreSQL 数据库
这篇文章介绍了什么是Prisma以及如何在Node.js和TypeScript后端应用中使用它。Prisma是一个开源的下一代ORM,包含PrismaClient、PrismaMigrate、PrismaStudio等部分。文章详细叙述了安装PrismaCLI和依赖包、初始化Prisma、连接数据库、定义Prisma模型、创建Prisma模块的过程,并对比了Prisma和Sequelize在Nest.js中的使用体验,认为Prisma更加便捷高效,没有繁琐的配置。
181 7
Nest.js 实战 (二):如何使用 Prisma 和连接 PostgreSQL 数据库
|
3月前
|
关系型数据库 MySQL 数据库
postgresql使用mysql_fdw连接mysql
通过以上步骤,你可以在PostgreSQL中访问和查询远程MySQL服务器的数据,这对于数据集成和多数据库管理非常有用。
239 0
|
4月前
|
分布式计算 DataWorks 关系型数据库
DataWorks操作报错合集之使用连接串模式新增PostgreSQL数据源时遇到了报错"not support data sync channel, error code: 0001",该怎么办
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
3月前
|
SQL 关系型数据库 数据库
EF Core连接PostgreSQL数据库
EF Core连接PostgreSQL数据库
49 0
|
5月前
|
SQL 关系型数据库 PostgreSQL
PostgreSQL和greenplum的copy命令可以添加字段吗?
【6月更文挑战第5天】PostgreSQL和greenplum的copy命令可以添加字段吗?
91 3
|
5月前
|
监控 关系型数据库 数据库
PostgreSQL和greenplum的copy命令如何使用?
【6月更文挑战第5天】PostgreSQL和greenplum的copy命令如何使用?
153 2
|
6月前
|
关系型数据库 数据库 PostgreSQL
postgresql|【基于pg_basebackup命令的归档备份和恢复---热备冷恢复方式】
postgresql|【基于pg_basebackup命令的归档备份和恢复---热备冷恢复方式】
283 0
|
6月前
|
SQL JSON 关系型数据库
[UE虚幻引擎插件DTPostgreSQL] PostgreSQL Connector 使用蓝图连接操作 PostgreSQL 数据库说明
本插件主要是支持在UE蓝图中连接和操作PostgreSQL 数据库。
61 2