[英]Search for documents in elasticsearch and then query the nested fields
[英]Elasticsearch search query with nested fields
我正在使用elasticsearch上的简历数据库。 有嵌套的字段。 例如,有一个“技能”部分。 “技能”是包含“技能”和“年”的嵌套字段。 我希望能够执行一个返回特定年份技能的查询。 例如,我想获得具有3年或更长时间“蟒蛇”经验的人的简历。
我已成功运行执行以下操作的查询:
它返回所有简历,其中“python作为技能。技能,3作为技能。年份返回结果,其中python与2年或经验相关,只要其他一些领域与3年的经验相关联。
GET /resumes/_search
{
"query": {
"bool": {
"must": [
{ "match": { "skills.skill": "python" }},
{ "match": { "skills.years": 3 }}
]
}
}
}
有没有更好的方法来排序数据,其中3与python更相关?
您在当前模型中拥有的内容似乎是基本对象模型 。
我在下面提到了示例映射,示例文档,嵌套查询和响应。 这会给你你想要的东西。
PUT resumes
{
"mappings": {
"mydocs": {
"properties": {
"skills": {
"type": "nested",
"properties": {
"skill": {
"type": "keyword"
},
"years": {
"type": "integer"
}
}
}
}
}
}
}
POST resumes/mydocs/1
{
"skills": [
{
"skill": "python",
"years": 3
},
{
"skill": "java",
"years": 3
}
]
}
POST resumes/mydocs/2
{
"skills": [
{
"skill": "python",
"years": 2
},
{
"skill": "java",
"years": 3
}
]
}
POST resumes/_search
{
"query": {
"nested": {
"path": "skills",
"query": {
"bool": {
"must": [
{
"match": {
"skills.skill": "python"
}
},
{
"match": {
"skills.years": 3
}
}
]
}
}
}
}
}
{
"took": 1,
"timed_out": false,
"_shards": {
"total": 5,
"successful": 5,
"failed": 0
},
"hits": {
"total": 1,
"max_score": 1.6931472,
"hits": [
{
"_index": "resumes",
"_type": "mydocs",
"_id": "1",
"_score": 1.6931472,
"_source": {
"skills": [
{
"skill": "python",
"years": 3
},
{
"skill": "java",
"years": 3
}
]
}
}
]
}
}
请注意,您只检索上述响应中ID为1
的文档。 另请注意,为了简单起见,我将技巧.skill作为keyword
类型。 您可以根据用例将其更改为text
。
希望能帮助到你!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.