[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]升级pg9到13,pg_upgrade: "数据库 "postgres" 的 lc_collate 值不匹配"

上一篇:[备忘]pg_upgrade命令报错:"pg_upgrade_internal.log": Permission denied
下一篇:[备忘]linux创建30个目录,每个目录1万个文件,写点内容

添加日期:2024/11/6 18:44:01 快速返回   返回列表 阅读42次
升级pg库时,主要是postgres和template1两个库的lc_collate要相同。
不相同,只能重新创建了。

psql -h 127.0.0.1 -U postgres -p 5432
(1)默认是postgres库,先把template1干掉,重建。
-------------------------
ALTER database template1 is_template=false;

DROP database template1;

CREATE DATABASE template1
WITH OWNER = postgres
   ENCODING = 'UTF8'
   TABLESPACE = pg_default
   LC_COLLATE = 'C'
   LC_CTYPE = 'C'
   CONNECTION LIMIT = -1
   TEMPLATE template0;

ALTER database template1 is_template=true;
-------------------------
(2)然后切到template1,再干掉postgres库,重建
\c template1
DROP DATABASE postgres;
CREATE DATABASE postgres
   LC_COLLATE 'C' LC_CTYPE 'C'
   TEMPLATE template0;
(3)重启db
(4)查询:SHOW LC_COLLATE;
============================================
升级步骤:
(1)9和13的db都停止。
(2)设置变量,这是新库的密码
set PGPASSWORD=123456
我的旧库没有密码
(3)执行命令
pg_upgrade -b "D:\Program Files (x86)\xxx\pgsql\bin" -B "E:\Program Files\PostgreSQL\13\bin" -d "D:\Program Files (x86)\xxx\data" -D "E:\Program Files\PostgreSQL\13\data" -U postgres -p 5432 -P 5433 -o " -h 127.0.0.1" -O "-h 127.0.0.1"
具体参数意义,执行pg_upgrade --help
 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved