逻辑导入导出(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
相关推荐
KmSH8umpK7 分钟前
Redis分布式锁进阶第十二篇
数据库·redis·分布式
hERS EOUS12 分钟前
MySQL 函数
数据库·mysql
gQ85v10Db38 分钟前
Redis分布式锁进阶第十六篇:番外高阶避坑篇 + 隐性埋点锁故障深挖 + 疑难杂症终极兜底方案
数据库·redis·分布式
S1998_1997111609•X1 小时前
论恶意注入污染蜜罐进程函数值取仺⺋以集团犯罪获取数据爬虫的轮系依据
网络·数据库·爬虫·网络协议·百度
许彰午1 小时前
# 从OOM到根治的完整过程——导出大数据的应急、根因分析与游标方案
java·大数据·数据库·系统架构
eLIN TECE1 小时前
nacos2.3.0 接入pgsql或其他数据库
数据库
曾几何时`1 小时前
MySQL(七)索引
数据库·mysql
KmSH8umpK2 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第九篇
数据库·redis·分布式
悠悠121382 小时前
一条 SQL 从敲下回车,到在 MySQL 里“跑完一生”,中间到底经历了啥?
数据库·sql·mysql
秋92 小时前
MySQL 9.7.0 使用详解:新特性、实战与避坑指南
android·数据库·mysql