我在弹性搜索索引中创建了一个小数据集(目前只有8个项目)。
条目的结构如下
{
"value_a": "Foo",
"value_b": "Bar",
"value_c": "Baz"
}
在弹性搜索中,这看起来如下(取自直接查询我的弹性搜索端点):
{
"_index": "foo_bar_bazindex",
"_type": "foo_bar_baz",
"_id": "4",
"_score": 1,
"_source": {
"value_a": "Foo",
"value_b": "Bar",
"value_c": "Baz"
}
}
值a,b和c的组合是唯一的。
我想找到" value_c"的值通过使用值a和b执行bool过滤搜索。
在我的代码中,我一直在尝试如下:
$filter = new \Elastica\Filter\Bool();
$query = new \Elastica\Query();
$aFilter = new \Elastica\Filter\Term(['value_a' => "Foo"]);
$bFilter = new \Elastica\Filter\Term(['value_b' => "Bar"]);
$filter->addMust($aFilter);
$filter->addMust($bFilter);
$query->setFilter($filter);
$results = $this->bookingPeriodIndex->search($query)->getResults();
var_dump($results);
然而,这不会返回任何结果(var转储输出一个空数组) - 也可以通过将此查询直接发送到服务器来手动尝试此查询:
{
"query": {
"filtered": {
"filter": {
"bool": {
"must": [
{
"term": {
"value_a": "Foo"
}
},
{
"term": {
"value_b": "Bar"
}
}
]
}
}
}
}
}
这也没有产生任何结果 - 但我希望它能返回一个结果,因为我有以下条目:
{
"value_a": "Foo",
"value_b": "Bar",
"value_c": "Baz"
}
我错过了什么吗?可能是因为小数据集?我们在代码库的其他地方使用相同的Bool Filter Elastica查询,这些查询按预期工作,但我似乎无法从此索引中获取任何数据。
任何帮助都将不胜感激。
答案 0 :(得分:1)
最后,我通过使用带有两个匹配语句的bool查询得到了我正在寻找的结果:
原始查询:
{
"query": {
"bool": {
"must": [
{
"match": {
"value_a": "Foo"
}
},
{
"match": {
"value_b": "Bar"
}
}
]
}
}
}
使用Elastica的查询:
$query = new Query;
$booleanQuery = new Bool();
$fooMatch = new Match();
$fooMatch->setField('value_a', 'Foo');
$booleanQuery->addMust($fooMatch);
$barMatch = new Match();
$barMatch->setField('value_b', 'Bar');
$booleanQuery->addMust($barMatch);
$query->setQuery($booleanQuery);
$results = $this->index->search($query)->getResults();