逻辑导入导出(pg_dump/pg_restore)用法2-导入到不同的schema或tablespace

文章目录

文档用途

移动数据时,需要更换schema或tablespace

详细信息

逻辑导入导出,导入到不同的schema或tablespace

如果需要将数据导入到不同的schema,tablespace。如何做?

实现方式:将schema数据导出为Fp平面文件,及sql脚本的形式,然后替换sql脚本中的schema和tablespace,再将其导入到数据库中。

步骤如下:

1 使用pg_dump工具实现平面文件格式备份文件,将数据字典和表数据分开导出

如:导出schema pub数据

导出字典信息

sql 复制代码
pg_dump -Fp -s -v -n pub test -f /backup/pub_dic.dmp

导出表数据

sql 复制代码
pg_dump -Fp -a -v -n pub test -f /backup/pub_data.dmp

2 创建新的用户和schema

如:创建新用户和schema test_1209

sql 复制代码
psql -d tpsgdb -U postgres

create role prod_1209 with login password 'test_1209';

create schema if not exists test_1209;

grant all on schema prod_1209 to test_1209;

3 替换备份文件中schema的名字

如 将schema pub替换为schema test_1209

替换字典备份文件

sql 复制代码
sed -i "s/pub/test_1209/g" /backup/pub_dic.dmp

替换数据备份文件

sql 复制代码
sed -i "s/COPY pub/COPY test_1209/g" /backup/pub_data.dmp

4 替换替换字典备份文件中的tablespace参数设置

sql 复制代码
sed -i "s/default_tablespace='postgres'/default_tablespace='test'/g" /backup/pub_dic.dmp

5 导入数据到新schema和tablespace

如:

连接新用户

sql 复制代码
psql -d testt -U test_1209

or

tpsgdb=# \c testt test_1209

导入数据

sql 复制代码
tpsgdb=> \i /backup/pub_dic.dmp

tpsgdb=> \i /backup/pub_data.dmp
相关推荐
jnrjian20 小时前
text index 查看index column index定义 index 刷新频率 index视图
数据库·oracle
瀚高PG实验室21 小时前
审计策略修改
网络·数据库·瀚高数据库
言慢行善21 小时前
sqlserver模糊查询问题
java·数据库·sqlserver
韶博雅21 小时前
emcc24ai
开发语言·数据库·python
有想法的py工程师21 小时前
PostgreSQL 分区表排序优化:Append Sort 优化为 Merge Append
大数据·数据库·postgresql
迷枫7121 天前
达梦数据库的体系架构
数据库·oracle·架构
夜晚打字声1 天前
9(九)Jmeter如何连接数据库
数据库·jmeter·oracle
Chasing__Dreams1 天前
Mysql--基础知识点--95--为什么避免使用长事务
数据库·mysql
NineData1 天前
NineData 智能数据管理平台新功能发布|2026 年 3 月
数据库·oracle·架构·dba·ninedata·数据复制·数据迁移工具
小陈工1 天前
2026年4月7日技术资讯洞察:下一代数据库融合、AI基础设施竞赛与异步编程实战
开发语言·前端·数据库·人工智能·python