使用Elasticsearch在Symfony项目中的搜索结果

时间:2019-04-18 14:22:37

标签: php symfony elasticsearch elastica foselasticabundle

问题:

我有以下问题。我可以使用SKU搜索我的数据。但是由于有多个分销商,我想按SKU和分销商进行过滤。但是我该怎么做,到目前为止,我是

PHP

$finder = $this->getContainer()->get('fos_elastica.finder.product.productstock');
$query = new \Elastica\Query\MultiMatch();
$query->setFields(["sku", "distributor"]);
$query->setQuery('XXXXXX');
$productStock = $finder->find($query);
dump($query);
dump($productStock);exit;

$ query 转储:

Elastica\Query\MultiMatch {#900
  #_params: array:2 [
    "fields" => array:2 [
      0 => "sku"
      1 => "distributor"
    ]
    "query" => "XXXXXXXX"
  ]
  #_rawParams: []
}

查询结果:

array:2 [
  0 => AppBundle\Entity\ProductStock {#970
    -id: 16218
    -sku: "XXXXXX"
    -stock: 90
    -price: "11.00"
    -distributor: "XXX"
  }
  1 => AppBundle\Entity\ProductStock {#938
    -id: 54086
    -sku: "XXXXXX"
    -stock: 25
    -priceOverride: "11.00"
    -distributor: "XXX"   
  }
]

数据库表ProductStock

+---+-----+------+--------+-------+
|id | sku |stock | vendor | price |
+---+-----+------+--------+-------+

我的目标目标是,如果SKU和分配器匹配,则从Elasticsearch结果中获得1个数组。

1 个答案:

答案 0 :(得分:2)

您需要设置查询类型:

$query->setType(self::TYPE_BEST_FIELDS);
$query->setOperator(self::OPERATOR_AND);

如果这不起作用:

$query->setType(self::TYPE_MOST_FIELDS);

说明:

  

在查询多个字段时,most_fields类型最有用   包含以不同方式分析的相同文本

查看更多详细信息here