elasticsearch之query-----执行Search

来源:互联网 发布:数据采集有哪几种接头 编辑:程序博客网 时间:2024/05/18 00:27

执行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" } }      ]    }  }}
0 0
原创粉丝点击