繁体   English   中英

typeorm 在 jsonb 列属性上添加索引

[英]typeorm add index on jsonb column property

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

谢谢

我没有做你所要求的事情的经验,但我确实找到了这篇关于 GIN 索引的文章 所以如果你有这张桌子

CREATE TABLE test(id int, data JSONB, PRIMARY KEY (id));

您可以在其上创建 GIN 索引:

CREATE INDEX datagin ON books USING gin (data);

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

然后,您还需要运行自定义 SQL 以使用带有路径运算符 @>, <@的索引:

select * from books where data @> '{"braille":true}'::jsonb;

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

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM