💡
原文英文,约3500词,阅读约需13分钟。
📝
内容提要
本文讨论了升级和更新PostgreSQL时可能出现的字符排序规则不匹配的问题,解决方法是重新初始化新版本的PGDATA目录并明确指定排序规则。建议使用二进制排序规则(C/POSIX)以稳定排序规则并避免未来问题。
🎯
关键要点
- 字符排序规则决定了字符的排序顺序和分类。
- PostgreSQL在创建数据库时通常根据操作系统的区域设置设置排序规则。
- Linux系统上的glibc更新可能会导致排序规则的变化,可能导致索引损坏。
- pg_upgrade检查失败的错误信息为:数据库'postgres'的lc_collate值不匹配。
- 当旧版本和新版本的PostgreSQL数据库的默认排序规则不匹配时,pg_upgrade一致性检查将失败。
- 解决方法是重新初始化PGDATA目录,并明确指定编码和排序规则。
- 建议使用二进制排序规则(C/POSIX)以稳定排序规则并避免未来问题。
- 二进制排序规则在性能上也有优势。
- 在初始化数据目录时,最好明确指定要使用的排序规则,避免使用系统默认值。
- 确保在升级后,所有数据库的编码和排序规则与旧版本一致。
➡️