暂无图片
pg_restore异机恢复
我来答
分享
ss
2024-11-05
pg_restore异机恢复

源库:psql (PostgreSQL) 9.4.26 

目标库:psql (PostgreSQL) 9.4.24

将原库testdb下tmp schema导入到目标库tdb下tmp schema,

pg_dump -d testdb -n tmp -t tmp.test1 -t tmp.test2 -Fd -j2 -f tmpbak1104
pg_restore -d tdb -n tmp -O tmpbak1104 -j2

导人时报错:

pg_restore: [archiver (db)] pg_restore: [archiver (db)] Error from TOC entry 122280; 0 0 ACL TABLE bi_dm_asset_mid_cust_month_his analyst
Error from TOC entry 122281; 0 0 ACL TABLE bi_dm_fund_stock analyst
pg_restore: [archiver (db)] pg_restore: [archiver (db)] could not execute query: ERROR: role "analyst" does not exist
Command was: REVOKE ALL ON TABLE tmp.bi_dm_asset_mid_cust_month_his FROM PUBLIC;
REVOKE ALL ON TABLE tmp.bi_dm_asset_mid_cust_month_his F...
could not execute query: ERROR: role "analyst" does not exist
Command was: REVOKE ALL ON TABLE tmp.bi_dm_fund_stock FROM PUBLIC;
REVOKE ALL ON TABLE tmp.bi_dm_fund_stock FROM analyst;
GRANT ALL ON TA...


postgresql 数据库在导入时,怎么忽略类似授权的错误,还是说必须要把对应的role全部建好?

我来答
添加附件
收藏
分享
问题补充
1条回答
默认
最新
寻寻觅觅

1、目标库创建角色,跟源库保持一致

2、导入时,忽略权限设置

pg_restore -d tdb -n tmp --no-owner --no-acl -j2 tmpbak1104

--no-owner:忽略所有者信息
--no-acl:忽略访问控制列表(ACL)信息

3、修改导出的文件,就是保留权限设置,但不想创建角色,可以加上 --no-acl 参数

pg_dump -d testdb -n tmp -t tmp.test1 -t tmp.test2 -Fd -j2 --no-acl -f tmpbak1104


目标库不想创建角色可以试试2、3

暂无图片 评论
暂无图片 有用 3
打赏 0
ss
题主
2024-11-08
-O参数已经加了,但是没看到有no-acl的参数,你是什么版本
回答交流
Markdown


请输入正文
提交
相关推荐
postgresql时间类型的,挂什么索引比较好?
回答 1
普通索引
pg_top安装失败
回答 2
参考文章<pgtop安装及使用说明>:https://cdn.modb.pro/db/251500
postgresql从pg_roles里面查到的角色为什么比\du多?
回答 1
元命令输出结果通常会忽略内部的对象
Postgresql 的function 有什么参数可以优化的吗?
回答 2
已采纳
有两个方法:一个是编程得语言可以选择SQL和Pl/pgsql,另一个方面是与函数的稳定性参数有关。下面有一篇关于创建索引的文章,你可以参考下使用函数及表达式索引部分。
pg高可用实战方面的电子书,
回答 2
建议购买正版书籍,到墨值商城看看,https://www.modb.pro/point/mall《PostgreSQL高可用实战》《PostgreSQL修炼之道:从小工到专家》《openGauss数据
pg_bulkload安装出错
回答 1
cannotfindlpam>找不到pam,缺少依赖包pamdevel
高并发下,原生pg是否有性能波动的情况
回答 1
有没有波动建议在你自己的业务场景下进行高并发压测。
postgresql 有没这种功能。 我有一个物料表,删除和更新都自动写入redis?
回答 4
已采纳
我觉得没有哪个库有这个功能。都需应用自己实现。
postgreSQL有类似sql 的公共临时表吗?
回答 2
看下是否帮助到你
pg12,分区表能否在线添加几个分区?
回答 1
在PostgreSQL12中,分区表是支持在线添加新分区的。这意味着你可以在不影响现有分区数据读写的情况下增加新的分区。添加新分区的操作本身是一个DDL(数据定义语言)操作,它不会锁定整个表,因此不会
问题信息
请登录之后查看
邀请回答
暂无人订阅该标签,敬请期待~~