在数组子对象上为 ILIKE 运算符创建 Postgres JSONB 索引

发布于 2025-01-11 19:21:29 字数 842 浏览 1 评论 0原文

我有一个已转换为 jsonb 列的表,如下所示:

cast: [
  { name: 'Clark Gable', role: 'Rhett Butler' },
  { name: 'Vivien Leigh', role: 'Scarlett' },
]

我正在尝试查询 jsonb 对象数组中的名称。这是我的查询:

SELECT DISTINCT actor as name
FROM "Title", 
jsonb_array_elements_text(jsonb_path_query_array("Title".cast,'$[*].name')) actor
WHERE actor ILIKE 'cla%';

有没有办法为这样的查询建立索引?我尝试过将 BTREE、GIN、GIN 与 gin_trgm_ops 一起使用,但没有成功。 我的尝试:

CREATE INDEX "Title_cast_idx_jsonb_path" ON "Title" USING GIN ("cast" jsonb_path_ops);
CREATE INDEX "Title_cast_idx_on_expression" ON "Title" USING GIN(jsonb_array_elements_text(jsonb_path_query_array("Title".cast, '$[*].name')) gin_trgm_ops);

问题之一是 jsonb_array_elements_text(jsonb_path_query_array()) 返回一组无法索引的集合。使用 array_agg 似乎没有用,因为我需要提取名称值,而不仅仅是检查是否存在。

I have a table that has cast as jsonb column, which looks like this:

cast: [
  { name: 'Clark Gable', role: 'Rhett Butler' },
  { name: 'Vivien Leigh', role: 'Scarlett' },
]

I'm trying to query name in the jsonb array of objects. This is my query:

SELECT DISTINCT actor as name
FROM "Title", 
jsonb_array_elements_text(jsonb_path_query_array("Title".cast,'$[*].name')) actor
WHERE actor ILIKE 'cla%';

Is there a way to index a query like this? I've tried using BTREE, GIN, GIN with gin_trgm_ops with no success.
My attempts:

CREATE INDEX "Title_cast_idx_jsonb_path" ON "Title" USING GIN ("cast" jsonb_path_ops);
CREATE INDEX "Title_cast_idx_on_expression" ON "Title" USING GIN(jsonb_array_elements_text(jsonb_path_query_array("Title".cast, '$[*].name')) gin_trgm_ops);

One of the issues is that jsonb_array_elements_text(jsonb_path_query_array())returns a set which can't be indexed. Using array_agg doesn't seem useful, since I need to extract name value, and not just check for existence.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文