Код: Выделить всё
public async Task GetRapbacksAsync(DateTime startDate, DateTime endDate, string destination)
{
ElasticsearchClient localClient = GetClient(destination);
var rapbacks = await localClient.SearchAsync(SUBMISSION_INDEX, s => s
.Query(q => q
.Bool(b => b
.Should( // Changed Must to Should for OR condition
ss => ss.Term(tt => tt.Field(f => f.Tot).Value("RBIHS".ToLower())),
ss => ss.Term(tt => tt.Field(f => f.Tot).Value("RBMNT".ToLower())),
ss => ss.Term(tt => tt.Field(f => f.Tot).Value("RBSCRM".ToLower())),
ss => ss.Term(tt => tt.Field(f => f.Tot).Value("RBN".ToLower())),
ss => ss.Term(tt => tt.Field(f => f.Tot).Value("RBSCVL".ToLower())),
ss => ss.Term(tt => tt.Field(f => f.Tot).Value("RBRPT".ToLower())),
ss => ss.Term(tt => tt.Field(f => f.Tot).Value("RBRPTR".ToLower()))
)
.MinimumShouldMatch(1) // At least one of the Should conditions must match
.Must(
ss => ss.Range(rr => rr
.DateRange(dr => dr
.Field(f => f.SubmissionCreation)
.Gte(startDate.ToString("yyyy/MM/dd"))
.Lte(endDate.ToString("yyyy/MM/dd"))
))))).Size(MAX_DOCUMENTS).Sort(sort => sort
.Field(f => f.SubmissionCreation, d => d.Order(SortOrder.Desc)))
);
return rapbacks;
}
Подробнее здесь: https://stackoverflow.com/questions/785 ... client-8-3