首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL炼金术索引on (UUID,JSONB)

SQL炼金术索引on (UUID,JSONB)
EN

Stack Overflow用户
提问于 2022-03-03 12:46:03
回答 2查看 311关注 0票数 0

我有一个带有模式的表,该表有一个json字段。该文件已经填充了大量数据。

代码语言:javascript
复制
CREATE TABLE table(
id     UUID      NOT NULL
data    JSON       NOT NULL
);

我想为json字段创建一个索引。我试过下面的脚本

代码语言:javascript
复制
 __table_args__ = (
                  Index("index_table_on_data_gin",
                        "data",
                        postgresql_using='gin',),
               
                  ),
                   Index("index_table_on_id_gin",
                        "id",
                        postgresql_using='gin',),
               
                  ),
                  )

这是我正在犯的错误。

JSON索引创建错误

代码语言:javascript
复制
sqlalchemy.exc.ProgrammingError: (psycopg2.errors.UndefinedObject) data type json has no default operator class for access method "gin"

UUID索引创建错误

代码语言:javascript
复制
sqlalchemy.exc.ProgrammingError: (psycopg2.errors.UndefinedObject) data type uuid has no default operator class for access method "gin"
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-03-03 14:43:17

您可以使用杜松子酒扩展来用GIN对UUID进行索引(尽管我不明白这一点,为什么不直接使用常规的btree呢?)

票数 2
EN

Stack Overflow用户

发布于 2022-03-03 14:01:18

不能索引json类型,但可以索引jsonb类型,请参阅手册jsonb应该是您首选的类型(参见手册)

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71337447

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档