问题:
我有以下问题。我可以使用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个数组。
答案 0 :(得分:2)
您需要设置查询类型:
$query->setType(self::TYPE_BEST_FIELDS);
$query->setOperator(self::OPERATOR_AND);
如果这不起作用:
$query->setType(self::TYPE_MOST_FIELDS);
说明:
在查询多个字段时,most_fields类型最有用 包含以不同方式分析的相同文本
查看更多详细信息here