typeorm 在 jsonb 列属性上添加索引

Aks*_*ood 2 postgresql typescript typeorm

我有一个表,其中有一jsonb列名为asset. 此列中的记录有一个名为 的字段value。我正在寻找一个选项来创建索引,asset.value但找不到它。有人可以帮我吗?我在用typeorm

谢谢

Jim*_*Jim 5

我没有执行您所要求的操作的经验,但我确实找到了这篇关于 GIN 索引的文章。所以如果你有这张桌子

CREATE TABLE test(id int, data JSONB, PRIMARY KEY (id));
Run Code Online (Sandbox Code Playgroud)

你可以在上面创建一个 GIN 索引:

CREATE INDEX datagin ON books USING gin (data);
Run Code Online (Sandbox Code Playgroud)

目前看来 TypeORM 不会支持这种类型的专用索引。请参阅此 github 问题。但是您可以手动将CREATE INDEX和添加DROP INDEX到 TypeORM 迁移up()down()函数中。

然后,您还需要运行自定义 SQL 来通过路径运算符 @>、<@使用索引:

select * from books where data @> '{"braille":true}'::jsonb;
Run Code Online (Sandbox Code Playgroud)

您可以使用 EntityManager API执行以下操作:

const rawData = await manager.query(`select * from books where data @> '{"braille":true}'::jsonb`);
Run Code Online (Sandbox Code Playgroud)