0

这是我的弹性搜索查询。我正在尝试获取所有满足 ifjob_id为 1 条件的文档,然后获取具有sourced = 0else ifjob_id不是 1 的文档,然后获取具有sourced = 1.

但它会返回所有文件。

[
'script' => 
    ['script' => 
        [
            'lang' => 'painless', 
            'source' => "(doc['job_id'].size() > 0 && doc['job_id'].value !==  params.jid) || (doc['job_id'].size() > 0 && doc['job_id'].value == params.jid && doc['sourced'].value == 0)",
            'params' => ['jid' => 1]
        ]
    ]
]

引用字段的映射

"job_id" : {
      "type" : "long"
    },
"sourced" : {
      "type" : "byte"
    },
4

1 回答 1

1

每个文档都由内联脚本评估。

一个示例(基于您的映射):

插入文档

PUT my_index/_doc/1
{
  "job_id": 1,
  "sourced": 0
}

PUT my_index/_doc/2
{
  "job_id": 0,
  "sourced": 2
}

搜索查询

GET my_index/_search (Kibana usage)
{
  "query": {
    "script": {
      "script": {
        "lang": "painless",
        "source": "doc['job_id'].value == params.jid ? doc['sourced'].value == 0 : doc['sourced'].value == 1",
        "params": {
          "jid": 1
        }
      }
    }
  }
}

您的使用情况

[
'script' => 
    ['script' => 
        [
            'lang' => 'painless', 
            'source' => "doc['job_id'].value == params.jid ? doc['sourced'].value == 0 : doc['sourced'].value == 1",
            'params' => ['jid' => 1]
        ]
    ]
]

结果

 "hits" : [
  {
    "_index" : "my_index",
    "_type" : "_doc",
    "_id" : "1",
    "_score" : 1.0,
    "_source" : {
      "job_id" : 1,
      "sourced" : 0
    }
  }
]

希望这可以帮助

于 2019-12-25T11:59:57.037 回答