我尝试学习如何将数据库导入PostgreSQL。
我的尝试失败了,我使用pg_restore -C ... -d ...
将创建新数据库和从文件导入到新数据库合并到一个命令中:
$ sudo -u postgres pg_restore -C -d postgres dvdrental.tar
pg_restore: [archiver (db)] Error while PROCESSING TOC:
pg_restore: [archiver (db)] Error from TOC entry 2194; 1262 17355 DATABASE pagila postgres
pg_restore: [archiver (db)] could not execute query: ERROR: invalid locale name: "English_United States.1252"
Command was: CREATE DATABASE pagila WITH TEMPLATE = template0 ENCODING = 'UTF8' LC_COLLATE = 'English_United States.1252' LC_CTYPE = 'English_United States.1252';
pg_restore: [archiver (db)] could not execute query: ERROR: database "pagila" does not exist
Command was: ALTER DATABASE pagila OWNER TO postgres;
pg_restore: [archiver (db)] could not reconnect to database: FATAL: database "pagila" does not exist
我的问题是:
我想知道为什么我的第一次尝试失败了?
有没有办法只运行一个命令?
该文件说:
-C --创造
在还原到数据库之前创建数据库。如果还指定了 --clean,则在之前删除并重新创建目标数据库 连接到它。
甚至举个例子:
假设我们已经将一个名为 mydb 的数据库转储为自定义格式 转储文件:
$ pg_dump -Fc mydb > db.dump
删除数据库并从转储中重新创建数据库:
$ dropdb mydb $ pg_restore -C -d postgres db.dump
-d 开关中命名的数据库可以是 集群;pg_restore 仅使用它来发布 CREATE DATABASE 命令 mydb .使用 -C 时,数据总是恢复到 转储文件中显示的数据库名称。
谢谢。
更新:
再次感谢。我发现转储中toc.dat
的二进制文件包含
CREATE DATABASE pagila WITH TEMPLATE = template0 ENCODING = 'UTF8' LC_COLLATE = 'English_United States.1252' LC_CTYPE = 'English_United States.1252';`
是否可以修改它以使sudo -u postgres pg_restore -C -d postgres dvdrental.tar
工作?
请注意,我有一个工作解决方案:
在psql
中单独创建新数据库,并从文件导入到新数据库:
template1=# CREATE DATABASE dvdrental;
CREATE DATABASE
$ sudo -u postgres pg_restore -d dvdrental dvdrental.tar
$
导入失败,因为您尝试导入转储的操作系统不知道区域设置English_United States.1252
。操作系统不是 Windows,或者 Windows 没有安装该区域设置。
pg_restore -C
尝试以与原始系统上相同的方式创建数据库,这是不可能的。显式创建数据库有效,因为它使用存在的区域设置。
除了存在区域设置之外,无法使该CREATE DATABASE
命令成功,因此如果无法做到这一点,则必须运行两个命令来还原转储。