欢迎投稿

今日深度:

elasticsearch之query-----执行Search,

elasticsearch之query-----执行Search,


执行Search
在之前的讲述中,我们已经学会了一些基本的搜索参数,今天我们来进一步探讨Query DSL。我们先来看看返回的文档中的部分字段。
我们不希望返回所有字段,只返回我们需要的字段


下面例子显示出只返回 account_numer和 balance字段

GET /bank/_search
{
  "query": { "match_all": {} },
  "_source": ["account_number", "balance"]
}

上面Query方法中,只返回选中的字段,类似于SQL中的select * from table与 select account_number, balance from table等等。


现在我们来看看查询部分
之前我们有了解到match_all是查询匹配所有文档。现在我们介绍一个match查询的新查询形式(即对特定字段或一组字段进行搜索)。
此例返回的账号为20:

GET /bank/_search
{
  "query": { "match": { "account_number": 20 } }
}

下面这个例子返回address包含mill的所有账户:

GET /bank/_search
{
  "query": { "match": { "address": "mill" } }
}

下面这个例子返回address包含mill或 lane的所有账户:

GET /bank/_search
{
  "query": { "match": { "address": "mill lane" } }
}

相比于match,match_phrase匹配词组
下面这个例子返回address包含{ mill lane }这个词组的所有账户:

GET /bank/_search
{
  "query": { "match_phrase": { "address": "mill lane" }}
}

接下来介绍bool(ean)query。bool可以将许多个小的查询合并成一个大的查询。
下面这个例子,返回address同时包含mill和lane的所有账户:

GET /bank/_search
{
  "query": {
    "bool": {
      "must": [
        { "match": { "address": "mill" } },
        { "match": { "address": "lane" } }
      ]
    }
  }
}

在上面的例子中,该bool must子句指定文档被认为是匹配的所有查询必须是真的。

相比之下,此示例组成两个match查询,并返回address包含“mill”或“lane”的所有账户:

GET /bank/_search
{
  "query": {
    "bool": {
      "should": [
        { "match": { "address": "mill" } },
        { "match": { "address": "lane" } }
      ]
    }
  }
}

在上面的例子中,该bool should子句指定一个查询的列表,对于一个被认为是一个匹配的文档,它们必须是真的。

此示例组成两个match查询,并返回address中既不包含“mill”也不包含“lane”的所有帐户:

GET /bank/_search
{
  "query": {
    "bool": {
      "must_not": [
        { "match": { "address": "mill" } },
        { "match": { "address": "lane" } }
      ]
    }
  }
}

在上面的例子中,该bool must_not子句指定一个查询列表,对于一个被认为是一个匹配的文档,这个查询的列表都不是true。

我们可以在查询中同时结合must,,should和must_not子句bool。此外,我们可以bool在任何这些bool子句中撰写查询,以模拟任何复杂的多级布尔逻辑。

此示例返回任何40岁,但不住ID(aho)的人的所有帐户:

GET /bank/_search
{
  "query": {
    "bool": {
      "must": [
        { "match": { "age": "40" } }
      ],
      "must_not": [
        { "match": { "state": "ID" } }
      ]
    }
  }
}

www.htsjk.Com true http://www.htsjk.com/Elasticsearch/32177.html NewsArticle elasticsearch之query-----执行Search, 执行Search 在之前的讲述中,我们已经学会了一些基本的搜索参数,今天我们来进一步探讨Query DSL。我们先来看看返回的文档中的部分字段。 我们不希望...
相关文章
    暂无相关文章
评论暂时关闭