Написание запросов ElasticSearch в C#

Я перешел от Sense к написанию запросов на C#. У меня проблема в соединении двух запросов или фильтров.

В смысле я использовал

"and":[

Есть идеи, как это сделать?

Вот один из запросов, которые я пытаюсь сделать

{
    "filtered" : {
        "query" : {
            "term" : { "name.first" : "shay" }
        },
        "filter" : {
            "and" : [
                {
                    "range" : {
                        "postDate" : {
                            "from" : "2010-03-01",
                            "to" : "2010-04-01"
                        }
                    }
                },
                {
                    "prefix" : { "name.second" : "ba" }
                }
            ]
        }
    }
}

// попытка //

filtered = new
{
    query = new
    {
        term = new
        {
            name.first = "shay"
        }
    },
    filter = new
    {
        and =   ? 
        [        ?
         {        ?
            range = new
            {
                postDate = new
                {
                    from = "2010-03-01",
                    to ="2010-04-01"
                }
            }

          },
          prefix = new
          {
            name.second = "ba"
          }
        ]
    }
};

2 ответа

Сначала запрос "и","отфильтрованный" был объявлен устаревшим в 2.0.0-бета1. Вместо этого используйте запрос bool.

вот как вы запрашиваете

ElasticClient db = new ElasticClient(uri);

            var nestSearchRequest = db.Search<dynamic>(new SearchRequest(indexName)
            {
                Query = new BoolQuery
                {
                    Must = new QueryContainer[] { new TermQuery { Field = "name.first", Value = "shay" } },
                    Filter = new QueryContainer[] { new DateRangeQuery { Field = "postDate", GreaterThanOrEqualTo = new DateTime(2010, 3, 1), LessThan = new DateTime(2010, 4, 1) }, new PrefixQuery { Field = "name.second", Value = "ba" } }
                }
            });

            var nestFluent = db.Search<dynamic>(
                s => s.Index(indexName).Type("").Query(
                    q=>q.Bool(
                        bq=>bq.
                            Must(q.Term("name.first","shay")).
                            Filter(
                                q.DateRange(drq => drq.Field("postDate").GreaterThanOrEquals(new DateTime(2010, 3, 1)).LessThan(new DateTime(2010, 4, 1))),
                                q.Prefix("name.second", "ba")))));

            var lowLevelQuery = db.LowLevel.Search<dynamic>(indexName, new
            {
                query = new
                {
                    @bool = new
                    {
                        must = new { term = new Dictionary<string, string> { { "name.first", "shay" } } },
                        filter = new object[]
                        { 
                            new { range = new { postDate = new  { gte = new DateTime(2010, 3, 1), lt = new DateTime(2010, 4, 1) } } },
                            new { prefix = new Dictionary<string,string>{ { "name.second", "ba" }  } }
                        }
                    }
                }
            });

            var rawJSON = db.LowLevel.Search<dynamic>(indexName, @"{""query"":{ ""bool"":{ ""must"":{ ""term"":{ ""name.first"":""shay"" } },""filter"":[{ ""range"":{ ""postDate"":{ ""gte"":""2010-03-01"",""lt"":""2010-04-01"" } } },{ ""prefix"":{ ""name.second"":""ba"" } }] } }}");

Не знаю, что вы имеете в виду, но похоже, что вы хотите написать объект json, тогда не знаете, как писать после and =,
Я думаю, что вы должны написать так
and = new object[]{ new {range = new { a = "b"}}, new {prefix = new { c = "d"}} }
Я думаю, что-то вроде этого вы хотите.

Другие вопросы по тегам