嵌套查询以在 bool 中写入 must 和 should
Nest query to write must and should in bool
我想编写将产生如下结果的查询。 Bool 查询只需要一个 boolQueryDescriptior。我想改用两个 boolQueryDescriptors。
{
"query": {
"bool": {
"must": [
{
"term": {
"id": "idValue"
}
}
],
"should": [
{
"nested": {
"path": "nestedType",
"query": {
"match": {
"item2": "item2Value"
}
},
"inner_hits": {}
}
}
]
}
}
}
var results = client.Search<object>(sd => sd
.Query(q => q
.Bool(b => b
.Must(m => m
.Term("id", "idValue"))
.Should(s => s
.Nested(nq => nq
.Path("nestedType")
.Query(qd => qd
.Match(m => m
.OnField("item2")
.Query("item2Value")))
.InnerHits()))));
我想编写将产生如下结果的查询。 Bool 查询只需要一个 boolQueryDescriptior。我想改用两个 boolQueryDescriptors。
{
"query": {
"bool": {
"must": [
{
"term": {
"id": "idValue"
}
}
],
"should": [
{
"nested": {
"path": "nestedType",
"query": {
"match": {
"item2": "item2Value"
}
},
"inner_hits": {}
}
}
]
}
}
}
var results = client.Search<object>(sd => sd
.Query(q => q
.Bool(b => b
.Must(m => m
.Term("id", "idValue"))
.Should(s => s
.Nested(nq => nq
.Path("nestedType")
.Query(qd => qd
.Match(m => m
.OnField("item2")
.Query("item2Value")))
.InnerHits()))));