首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在jsonb字段PostgreSQL中的深度搜索

在jsonb字段PostgreSQL中的深度搜索
EN

Stack Overflow用户
提问于 2017-07-09 19:27:48
回答 2查看 13.7K关注 0票数 7

我的数据示例如下所示:

代码语言:javascript
复制
{"city": "NY", 
"skills": [
{"soft_skills": "Analysis"},
{"soft_skills": "Procrastination"},
{"soft_skills": "Presentation"}
],
"areas_of_training": [
{"areas of training": "Visio"},
{"areas of training": "Office"}, 
{"areas of training": "Risk Assesment"}
]}

我想运行一个查询来查找使用soft_skills Analysis的用户,或者运行另一个查询来查找培训领域为VisioRisk Assesment的用户。

我的列类型是jsonb。如何对这些深度嵌套的对象实现搜索查询?基于SELECT * FROM mydata WHERE content::json->>'city'='NY';的城市工程一级查询

如何使用LIKE关键字或字符串匹配深度嵌套的值来运行匹配?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-07-09 20:11:47

1)

代码语言:javascript
复制
SELECT * FROM mydata
WHERE content->'skills' @> '[{"soft_skills": "Analysis"}]';

2)

代码语言:javascript
复制
SELECT * FROM mydata
WHERE content->'areas_of_training' @> '[{"areas of training": "Visio"},{"areas of training": "Risk Assesment"}]';

关于JSON(B)算子

PS:并为非常慢的查询做好准备。我强烈建议考虑一下数据归一化

更新LIKE

对于您的示例数据,可以是:

代码语言:javascript
复制
SELECT * FROM mydata
WHERE EXISTS (
  SELECT *
  FROM jsonb_array_elements(content->'areas_of_training') as a
  WHERE a->>'areas of training' ilike '%vi%');

但是查询很大程度上取决于实际的JSON结构。

票数 13
EN

Stack Overflow用户

发布于 2017-07-10 06:40:29

使用json_array_elements()获取嵌套元素的值,例如:

代码语言:javascript
复制
select d.*
from mydata d,
json_array_elements(content->'skills')
where value->>'soft_skills' ilike '%analysis%';

select d.*
from mydata d,
json_array_elements(content->'areas_of_training')
where value->>'areas of training' ~* 'visio|office';

查询可能产生重复行,因此使用select distinct on (id)是合理的,其中id是主键。

请注意,函数json_array_elements()是昂贵的,您不能使用与Abelisto的解决方案相反的索引。但是,如果您想要访问嵌套的json元素的值,就必须使用它。

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

https://stackoverflow.com/questions/45000199

复制
相关文章

相似问题

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