2

我对 elasticsearch 不熟悉,并尝试与 elastica 相处。当其中一个是 2 和/或 7 时,我试图找出一组项目中哪些项目经常一起出现。因此索引包含许多嵌套的项目集。相互项目将使用构面提取。但我似乎没有将以下查询转换为 elastica:

curl -X POST "http://localhost:9200/ratings/rating/_search?pretty=true" -d '
{
  "query": {
    "terms": {
      "bookid": [2, 7],
      "minimum_match" : 1
    }
  },
  "size": 0,
  "facets": {
    "bookid": {
      "terms": {
        "field": "bookid"
      }
    }
  }
}'

我正在尝试这个:

        // Load index
        $index = $client->getIndex('ratings');
        $type = $index->getType('rating');


        // We want a Terms query.
        $query = new Elastica_Query_Terms();


        // Setting Terms
        $query->setTerms('bookid', $bookids);

        // Facets
        $facet = new Elastica_Facet_Query('matches');
        $facet->setField( 'bookid' )
            ->setSize(100);
        $facet->setQuery($query);

        $resultSet = $type->search($query);
        return $resultSet;

但到目前为止还没有运气。如何添加构面属性?

4

1 回答 1

1

Elastica 查询类有一个 addFacet 方法,因此与其在 facet 上设置查询,不如将 facet 添加到查询中更有意义。

$facet = new Elastica_Facet_Query('matches');
$facet->setField('bookid')
      ->setSize(100);

$query = new Elastica_Query_Terms();
$query->setTerms('bookid', $bookids);
$query->addFacet($facet);
于 2014-02-12T14:22:25.083 回答