在jsonb字段PostgreSQL中进行深度搜索

在jsonb字段PostgreSQL中进行深度搜索,postgresql,jsonb,Postgresql,Jsonb,我的数据示例如下所示: {"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":

我的数据示例如下所示:

{"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"}
]}
我想运行一个查询以查找具有软硬件技能的用户
分析
,或者运行另一个查询以查找培训领域为
Visio
风险评估

我的列类型是
jsonb
。如何在这些深度嵌套的对象上实现搜索查询?城市的一级查询使用mydata中的
SELECT*,其中content::json->>“城市”='NY'

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

1)

(二)

PS:并且准备好进行非常慢的查询。我强烈建议你考虑一下


更新类似的

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

SELECT * FROM mydata
WHERE EXISTS (
  SELECT *
  FROM jsonb_array_elements(content->'areas_of_training') as a
  WHERE a->>'areas of training' ilike '%vi%');

但是查询高度依赖于实际的JSON结构。

使用
JSON\u array\u elements()
获取嵌套元素的值,例如:

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\u array\u elements()
的成本很高,您不能使用与Abelisto的解决方案相反的索引。但是,如果您想访问嵌套json元素的值,就必须使用它。

我对问题进行了编辑,以包括使用LIKE关键字或字符串匹配的可能性。我希望有一个更好的规范化结构,但这些数据来自某个动态表单生成器,因此需要找到绕过其结果的方法结构。考虑将数据自动导入到归一化表(S)中。“丘吉尔,好的,明白了。关于慢速性能的评论,可以用GIN索引来解决吗?”虽然我必须将列数据类型更改为json而不是jsonb,但这也可以工作,以便json_数组_元素在不使用强制转换的情况下使用
如果列是
jsonb
只需使用
jsonb_数组_元素()
SELECT * FROM mydata
WHERE EXISTS (
  SELECT *
  FROM jsonb_array_elements(content->'areas_of_training') as a
  WHERE a->>'areas of training' ilike '%vi%');
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';