Aks*_*ood 2 postgresql typescript typeorm
我有一个表,其中有一jsonb列名为asset. 此列中的记录有一个名为 的字段value。我正在寻找一个选项来创建索引,asset.value但找不到它。有人可以帮我吗?我在用typeorm。
谢谢
我没有执行您所要求的操作的经验,但我确实找到了这篇关于 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)
| 归档时间: |
|
| 查看次数: |
3322 次 |
| 最近记录: |