在 jsonb 字段上添加索引
add index on jsonb field
我需要在 Postgres 中搜索 jsonb 字段的数组键的值。
field: {'array_key' : [1, 2, 3, 4]}
是否可以在 array_key
上添加索引,或者是否有任何优化的方法来搜索值?
搜索查询类似于
select * where field['array_key'].include?(2)
您可以在 jsonb 键上创建索引,
add_index :table_name, :field, :using => :gin, :expression => "(field->'array_key')", :name => 'index_table_name_on_field_array_keys'
然后,您可以搜索索引键,
where("table_name.field->'array_keys' @> ?", Array(2))
鉴于您有一个 'pictures' table 和 'metadata' jsonb 列
add_index(
:pictures,
"(metadata->>'Year')",
name: "index_pictures_on_metadata_year"
)
应该输出类似
的内容
CREATE INDEX "index_pictures_on_metadata_year" ON "pictures" ((metadata->>'Year'))
我需要在 Postgres 中搜索 jsonb 字段的数组键的值。
field: {'array_key' : [1, 2, 3, 4]}
是否可以在 array_key
上添加索引,或者是否有任何优化的方法来搜索值?
搜索查询类似于
select * where field['array_key'].include?(2)
您可以在 jsonb 键上创建索引,
add_index :table_name, :field, :using => :gin, :expression => "(field->'array_key')", :name => 'index_table_name_on_field_array_keys'
然后,您可以搜索索引键,
where("table_name.field->'array_keys' @> ?", Array(2))
鉴于您有一个 'pictures' table 和 'metadata' jsonb 列
add_index(
:pictures,
"(metadata->>'Year')",
name: "index_pictures_on_metadata_year"
)
应该输出类似
的内容CREATE INDEX "index_pictures_on_metadata_year" ON "pictures" ((metadata->>'Year'))