PostgreSQL逻辑备份恢复--pg_dump导出及psql导入案例
admin
2023-02-08 22:00:33
0

数据库导入导出是最常用的功能之一。PostgreSQL的备份工具可以使用pg_dump及pg_dumpall。可以通过pg_dump --help获取其使用方法。这里不对其做过多介绍。主要介绍在使用pg_dump及恢复过程中遇到的一个问题。

1、问题
使用pg_dump -c导出后,通过psql导入时报下面的错误:

ERROR:  relation "t1" already exists
ERROR:  duplicate key value violates unique constraint "t1_pkey"
ERROR:  multiple primary keys for table "t1" are not allowed

2、导入导出的操作

pg_dump -U postgres -d yzs -Fa -c -C -f all.sql
psql < all.sql

3、问题分析
1)通过-c导出时在重建database前先drop
2)通过-C导出时导出时导出create database语句
3)每次导入时,虽然库中已有导入的表结构和部分数据,及先执行drop database语句清空,应该不会出现表已存在等错误,但是这种错误确实出现了。原来,在导入时,只要已有连接连着这个database,drop语句就不会执行成功,导致清理数据库失败,后续执行对应语句时会报已存在、重复键、多个主键等错误。
4、解决方法
1)pg_dump导出时,没有选项使导出的语句中带if not exists,不能使之不存在时再创建或插入。
2)保证没有业务连接数据库时才导入,或向一个干净的数据库进行导入

相关内容

热门资讯

最新引进“普通牌九透视开挂器?... 网上科普关于“普通牌九透视有没有挂”话题很是火热,小编也是针对普通牌九透视作*弊开挂的方法以及开挂对...
2025年流量卡怎么选?这3款... 办卡:微 信 公 众 号 搜【 可可 找卡】,每天更新运营商官方高性价比套餐!帮你精准匹配适配流量方...
我来教教您“天蝎牛牛开挂器?”... 有 亲,根据资深记者爆料天蝎牛牛是可以开挂的,确实有挂(咨询软件无需打开...
今日重大消息“欢乐龙城3怎么装... 网上科普关于“欢乐龙城3有没有挂”话题很是火热,小编也是针对欢乐龙城3作*弊开挂的方法以及开挂对应的...
今日重大通报“麦穗怎么开挂?”... 家人们!今天小编来为大家解答麦穗透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买很多人...
玩家最新攻略“奕福麻将辅助器?... 网上科普关于“奕福麻将有没有挂”话题很是火热,小编也是针对奕福麻将作*弊开挂的方法以及开挂对应的知识...
【第一资讯】“开心跑胡子到底是... 【第一资讯】“开心跑胡子到底是不是挂?”(原来真的有挂)您好,开心跑胡子这个游戏其实有挂的,确实是有...
玩家最新攻略“中州游戏是不是有... 网上科普关于“中州游戏有没有挂”话题很是火热,小编也是针对中州游戏作*弊开挂的方法以及开挂对应的知识...
玩家分享攻略“普通扑克分析哪家... 网上科普关于“普通扑克分析哪家大小有没有挂”话题很是火热,小编也是针对普通扑克分析哪家大小作*弊开挂...
玩家分享攻略“胡乐邯郸麻将辅助... 您好:胡乐邯郸麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款...