4

Like C#(NEST), how can we write elastic search query using lambda expressions in JAVA. Below is the attached code which I have written using Elasticsearch JAVA client(HighlevelRestClient) . How can I write the code using lambda to reduce complexity for the below code.

static Map<String,float> fields1=new HashMap<>();
map.put("field1",1f);
...
...
..
...
public static List<Result> getSearch(QueryFilter[] qf,List<String> filter2,String input,String filter3) {
    SearchRequest searchRequest = new SearchRequest(esIndex);
    SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
    BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
    boolQueryBuilder.
    should(new MultiMatchQueryBuilder(input).minimumShouldMatch("2").type("phrase").boost(5f).fields(fields1)).
    should(new MultiMatchQueryBuilder(input).type("phrase").boost(5f).fields(fields2)).
    should(new MultiMatchQueryBuilder(input).operator(Operator.AND).type("cross_fields").fields(fields2)).
    should(new MultiMatchQueryBuilder(input).operator(Operator.OR).type("cross_fields").fields(fields3)).
    should(new MultiMatchQueryBuilder(input).fuzziness("AUTO").type("best_fields").fields(fields4));

    if(filter!=null && filter.length>0) {
        BoolQueryBuilder boolFieldQuery = new BoolQueryBuilder();
        for (QueryFilter qf : filter) {
            boolFieldQuery.must(QueryBuilders.matchQuery(qf.getName(), qf.getValue()));

        }
        boolQueryBuilder.filter(boolFieldQuery);
    }

    if(!(filter2==null || filter2.isEmpty())) {
        if(filter3==null || filter3.isEmpty() ) {
            for (String string : filter2) {
                boolQueryBuilder.should(new MultiMatchQueryBuilder(string).type("phrase_prefix").boost(10f).field("field1").field("field2"));
            }
            
        }
        else {
            for (String string : filter2) {
                boolQueryBuilder.should(new MultiMatchQueryBuilder(string).type("phrase_prefix").boost(10f).field(filter3));
            }
        }
    }
    
        searchSourceBuilder.query(boolQueryBuilder).size(50).from(0).sort(new ScoreSortBuilder().order(SortOrder.DESC));
        searchRequest.source(searchSourceBuilder);
        try {
            SearchResponse searchResponse = esclient.search(searchRequest, RequestOptions.DEFAULT);
            SearchHit[] hits = searchResponse.getHits().getHits();
            return Arrays.stream(hits).map(hit -> convert(hit.getSourceAsString(), Result.class)).collect(Collectors.toList());
        } catch (Exception e) {
            e.printStackTrace();
            return new ArrayList<>();
        }
    }


public static <T> T convert(String string, Class<T> pojo) {
        ObjectMapper objectMapper = new ObjectMapper();
        objectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
        try {
            return objectMapper.readValue(string, pojo);
        } catch (IOException e) {
            throw new UncheckedIOException(e);
        }
    }
rahul
  • 406
  • 1
  • 5
  • 14

1 Answers1

0

Really old question but it was the first search hit. All of the should queries can be written as:

.should(s -> s
  .multiMatch(m -> m
    .minimumShouldMatch("2")
    .type(TextQueryType.Phrase)
    .boost(5f)
    .fields(fields1);
  )
)
Nesta
  • 21
  • 4