2

我正在使用弹性搜索,我有两种类型来保存我的数据。

现在我需要使用单个查询从这两种类型中检索数据。

请看我的用例

我有两种类型,称为基本和标记,我保存文档如下

myindex/basic

{“id”:“100”,“名称”:“汤姆”}

myindex/basic

{“id”:“101”,“名称”:“约翰”

}

myindex/marks

{ “id”:“100”,“标记”:“300”

}

myindex/marks

{“id”:“101”,“标记”:“500”}

现在我需要得到一个学生的名字和标记,他的 id 是 100。

有没有可能得到这样的结果。

我开始知道这些类型的数据模型对 nosql 不利,但在这里我需要它,因为这些记录是从 RDBMS DB 复制的。

任何建议请提前致谢。

4

1 回答 1

1

您可以通过在 url 中列出它们来在单个查询中查询这两种类型

POST myindex/basic,marks/_search

您还可以通过 id 过滤所有这些

POST myindex/basic,marks/_search
{
  "query": {
    "bool": {
      "must": [
        {"term": {
          "id": {
            "value": 100
          }
        }}
      ]
    }
  }
}
于 2018-03-07T14:46:07.813 回答