[英]typeorm add index on jsonb column property
我有一个表,其中有一个名为asset
的jsonb
列。 此列中的记录有一个名为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 INDEX
和DROP 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.