Postgresql数据恢复编码

时间:2016-03-21 10:23:03

标签: windows postgresql-9.5

我无法恢复数据库脚本。

我已经关注了不同的帖子,这是我迄今为止要解决的问题:

1-将UTF-8旧数据库转储到LATIN9:

"C:\Program Files (x86)\pgAdmin III\1.22\pg_dump" -E LATIN9 --no-owner --no-acl -U postgres -W -h localhost -p 5432 database_name > database_name.sql

2-删除旧数据库

DROP DATABASE database_name;

3-将新数据库创建为LATIN9:

CREATE DATABASE "database_name" WITH ENCODING='LATIN9' OWNER=username TEMPLATE=template0 LC_COLLATE='C' LC_CTYPE='C' CONNECTION LIMIT=-1;

4-我尝试使用下一个命令恢复在第一步中创建的LATIN9脚本:

"C:\Program Files (x86)\pgAdmin III\1.22\psql.exe" -U username-d database_name -f database_name.sql

然后我收到错误消息:

  

psql:致命:不支持WIN1252和LATIN9之间的转换

我不明白,剧本已经是LATIN9 !!!发生了什么事? 我想补充一点,我尝试存档的是将当前的UTF-8数据库更改为LATIN9。

1 个答案:

答案 0 :(得分:0)

为了使它工作,我改变了步骤1和4。 这是更正的所有步骤:

1 -

"C:\Program Files (x86)\pgAdmin III\1.22\pg_dump" --host localhost --port 5432 --username "postgres" --role "postgres" --no-password  --format tar --blobs --encoding LATIN9 --verbose --file "database_name.backup" "database_name"

2 -

DROP DATABASE database_name;

3 -

CREATE DATABASE "database_name" WITH ENCODING='LATIN9' OWNER=username TEMPLATE=template0 LC_COLLATE='C' LC_CTYPE='C' CONNECTION LIMIT=-1;

4 -

"C:\Program Files (x86)\pgAdmin III\1.22\pg_restore" --host localhost --port 5432 --username "postgres" --dbname "database_name" --role "postgres" --no-password  --verbose "database_name.backup"