Hi,
I am trying to build a boolean query for full text search with PHP SDK but keep getting this error:
[cb,EROR] (pcbc/cbft L:35) Failed to search in index. 400: {“error”:“rest_index: Query, indexName: fts_index_custom, err: bleve: QueryBleve parsing searchRequest, err: json: cannot unmarshal array into Go value of type map[string]in
terface {}”,“request”:{“ctl”:{“timeout”:75000},“indexName”:“fts_index_custom”,“query”:{“must”:[{“conjuncts”:[{“field”:“name”,“match”:“ltd”},{“field”:“department”,“match”:“ltd”}]}]}},“status”:“fail”} . I=0x55e1f76bc8f0
By analyzing the error message it is obvious bleve parser is getting array as a “must” part of the query but it is expecting an object. There is an example of the boolean query in the docs and the “must” part of the query is clearly an object.
Query produced by PHP SDK
"ctl": { "timeout": 75000 }, "indexName": "fts_index_custom", "query": { "must": [ { "conjuncts": [ { "field": "name", "match": "ltd" }, { "field": "department", "match": "main" } ] } ] }
Query expected by Bleve parser (tested and works with FTS REST API)
"ctl": { "timeout": 75000 }, "indexName": "fts_index_custom", "query": { "must": { "conjuncts": [ { "field": "name", "match": "ltd" }, { "field": "department", "match": "main" } ] } }
This is the code I use to generate the query.
//Field queries
$firstQuery = SearchQuery::match("ltd")->field("name");
$secondQuery = SearchQuery::match("main")->field("department");
//Conjunction query for must part of the Boolean query
$mustConjunctsQuery = SearchQuery::conjuncts(
$firstQuery,
$secondQuery
);
//Boolean query
$booleanQuery = SearchQuery::boolean();
$booleanQuery->must($mustConjunctsQuery);
$query = new SearchQuery($indexName, $booleanQuery);
$result = $this->getBucket()->query($query);
My dev environment:
PHP SDK 2.6.1 (libcouchbase runtime version => 2.10.3)
Server Version: Community Edition 6.5.0 build 4966
Am I doing something wrong in the query composition or is this a bug in the SDK?
Thank you,
Emir