ElasticSearch按通配符过滤

时间:2017-03-14 15:27:35

标签: symfony elasticsearch foselasticabundle

我试图通过通配符来过滤我的结果。

我的记录示例:

....
"_source" : {
      "urlSlug" : "entry-title",
      "revisions" : [
        {
          "title" : "Entry title",
          "context" : "NKD"
        }
      ]
 }

每个修订版可以有不同的上下文,顺序不同。

当我搜索记录时,我想只搜索具有" N"等上下文的实体。所以我用match_all和wildcard执行嵌套查询。

{"query":{"bool":{"must":[{"query_string":{"query":"*entry*"}},{"nested":{"path":"revisions","query":{"bool":{"should":[{"match_all":{}}],"filter":[{"wildcard":{"revisions.context":{"value":"*N*","boost":1}}}]}}}}]}},"size":10}

当我运行查询时,我得到零结果。并且无法弄清楚如何限制结果。

我使用以下配置来使用此FosElastica:

indexes:
        app:
            types:
              entity:
                properties:
                    urlSlug: ~
                    revisions:
                      type: "nested"
                      properties:
                        title: { type: text,boost: 10 }
                        context: { type: text }

我的查询构建器如下所示:

$boolQuery = new ESQuery\BoolQuery();

    $fieldQuery = new ESQuery\QueryString();
    $fieldQuery->setQuery('*' . $query . '*');
    $boolQuery->addMust($fieldQuery);

        $nestedQuery = new ESQuery\Nested();
        $nestedQuery->setPath('revisions');

            $nestedBoolQuery = new ESQuery\BoolQuery();
                $matchAllQuery = new ESQuery\MatchAll();
            $nestedBoolQuery->addShould($matchAllQuery);

                $filterQuery = new ESQuery\Wildcard();
                $filterQuery->setValue('revisions.context','*N*');
            $nestedBoolQuery->addFilter($filterQuery);

        $nestedQuery->setQuery($nestedBoolQuery);


    $boolQuery->addMust($nestedQuery);

$result = $finder->findHybrid($boolQuery,self::AUTOCOMPLETE_MAX_RESULTS);

ElasticSearch版本5.2.2

1 个答案:

答案 0 :(得分:0)

我确实找到了查询中的问题。

这是一个工作:

{"query":{"bool":{"must":[{"query_string":{"query":"*komi*"}}],"filter":[{"nested":{"path":"revisions","query":{"wildcard":{"revisions.context":{"value":"*n*","boost":1}}}}}]}},"size":10}

整个问题是大写的通配符搜索。我一直在寻找*N*,结果为零,*n*就好了。