首页 > 解决方案 > AWS Aurora Postgres 12 设置排序规则

问题描述

我正在尝试将 AWS Aurora Postgres 12 上的排序规则设置为用户定义的排序规则类型。

CREATE COLLATION ndcoll (provider = icu, locale = 'und', deterministic = false);

我能够很好地创建排序规则。它最终被输入到 pg_collat​​ions 表中。

但是,当我尝试使用这个新的用户定义排序规则创建数据库时,我一直收到错误消息SQL Error [42809]: ERROR: invalid locale name: "ndcoll"

这是创建数据库语句:

create database "foo" with template 'bar' lc_collate = "ndcoll";

我知道还有一种方法可以使用自定义参数组在服务器级别设置排序规则。但是我使用 aurora-postgres 12 的参数组系列没有可用于设置排序规则的参数。创建用户定义的排序规则后,我重新启动了 Aurora 服务器,但仍然无法让数据库识别语言环境。我可能也不了解 locale 和 lc_collat​​e 。也许我从根本上存在误解。

是否有人对我如何使用用户定义的排序规则有任何见解 1)使用此用户定义的排序规则创建新数据库或 2)将服务器级别的排序规则设置为 aurora-postgres12 参数组中的非确定性排序规则家庭。

提前致谢!

标签: postgresqlamazon-web-servicescollationamazon-aurorapostgres-12

解决方案


您不能在CREATE DATABASE语句中使用 ICU 归类。

在未来的 PostgreSQL 版本中可能会取消该限制。目前,在 PostgreSQL 中拥有非确定性排序规则的唯一方法是在列级别使用它们。


推荐阅读