今天遇到的postgresql中的备份和恢复

今天遇到的postgresql中的备份和恢复,第1张

概述      老大让st把表给我,于是她发了备份数据库文件给我,居然是.backup后缀名(后来验证,是错给的windows下的备份文件了)因为我保存了却没有这个后缀,再让单独保存后给我,依旧不能还原。QQ是个很**的东东啊,发送文件,居然自动给我加上了.list和.dynamic后缀名        这后缀名是要我有多无语,自己备份下 发现了命令调用   上图的最上方       搜到了postg

老大让st把表给我,于是她发了备份数据库文件给我,居然是.backup后缀名(后来验证,是错给的windows下的备份文件了)因为我保存了却没有这个后缀,再让单独保存后给我,依旧不能还原。QQ是个很**的东东啊,发送文件,居然自动给我加上了.List和.dynamic后缀名


这后缀名是要我有多无语,自己备份下


发现了命令调用


上图的最上方

搜到了postgresql的文档http://www.postgresql.org/docs/8.1/static/backup.html,备份和还原,http://www.linuxsir.org/main/node/265(这个是中文版,不过有个问题,是不能-D选项为错,如下所示)

xia@ubuntu:~$ /usr/lib/postgresql/8.4/bin/pg_dump -D -h localhost -U sa example > example.bak
得到如下提示

/usr/lib/postgresql/8.4/bin/pg_dump: invalID option -- 'D'
Try "pg_dump --help" for more information.

根据上面个图最上行的提示,在st电脑上运行以下类似命令行:

xia@ubuntu:~$ /usr/bin/pg_dump --host 127.0.0.1 --port 5432 --username sa example > example.bak
再在我电脑上进行还原
xia@ubuntu:~$ /usr/lib/postgresql/8.4/bin/psql -h localhost -U sa -d example < example.bak

正确情况下,提示如下:

Password for user sa:
SET
SET
SET
SET
SET
SET
SET
SET
SET
CREATE table
ALTER table
CREATE table
ALTER table
CREATE table
ALTER table
ALTER table
ALTER table
ALTER table
ALTER table
ALTER table
CREATE INDEX
ALTER table
WARNING: no privileges Could be revoked for "public"
REVOKE
WARNING: no privileges Could be revoked for "public"
REVOKE
WARNING: no privileges were granted for "public"
GRANT
WARNING: no privileges were granted for "public"
GRANT

经验证,成功还原。

在我电脑上,也可以先删除example数据库

xia@ubuntu:~$ sudo -u postgres sh[sudo] password for xia: $ dropdb example

再新建数据库并退出

$ createdb -O sa example$ exit
用windows下的backup文件进行还原,则得到以下提示:

ERROR: Syntax error at or near "PGDMP"
liNE 1: PGDMP
REVOKE ALL ON SCHEMA public FROM postgres;
^
WARNING: no privileges were granted for "public"
GRANT
ERROR: Syntax error at or near ""
.......

ERROR: invalID byte sequence for enCoding "UTF8": 0xd302
HINT: This error can also happen if the byte sequence does not match the enCodingexpected by the server,which is controlled by "clIEnt_enCoding".

2个系统编码不同啊


其实用pgadmin3备份还原也可以的,只是新建数据库还是得通过命令行来,对标 *** 作可以直接图形化搞定。

成功情况下,退出码为0


不成功,则退出码为1

至此,搞定~~~

菜鸟go go go ~~~

总结

以上是内存溢出为你收集整理的今天遇到的postgresql中的备份和恢复全部内容,希望文章能够帮你解决今天遇到的postgresql中的备份和恢复所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1179658.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存