执行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" } }
]
}
}
}