nodejs 라이브러리를 사용하여 API에서 쿼리를 수정했지만 스토리에서 패싯을 잃어 버렸습니다.Marklogic (Nodejs API) - XPath 쿼리에서 패싯 추가
처음에는 queryBuilder를 사용하여 (패싯과 함께) 쿼리가 수행되었습니다.
var config = require('./config');
var db marklogic.createDatabaseClient(config.marklogic);
var qb = marklogic.queryBuilder;
var queryElements = [
qb.directory('/product/'),
qb.word('brand', 'myBrand')
/* we add optional conditions here */
];
// facets
var facetQuery = qb.where();
facetQuery.optionsName = 'search_option';
facetQuery.view = 'facets';
facetQuery.search = {
query: qb.and.apply(qb, queryElements)
};
return db.documents.query(facetQuery).result(function(documents) {
console.log(JSON.stringify(documents, null, 4));
});
이 쿼리는 경우에 따라 잘못된 데이터를 반환하므로 XPath 쿼리로 변경합니다.
var config = require('./config');
var db marklogic.createDatabaseClient(config.marklogic);
var query = 'xdmp:directory("/product")[ attr1 eq "" /* and some optional conditions */]/languages[ code eq "es_ES" and content/category eq "something" /* and some optional conditions */] ! root(.)';
return db.xqueryEval(query, {})
.result(function(results) {
console.log(JSON.stringify(results, null, 2));
});
쿼리가 제대로 작동하지만 이제는 호환성을 유지하기 위해 패싯을 추가해야합니다. nodejs 라이브러리 (documentation, example, tuto, ...)가있는 XPath 쿼리에 패싯을 추가하는 방법을 검색했지만 anyhing을 찾지 못했습니다.
내가 어떻게 할 수 있는지 알고 있니? 빌더 대신 문서화 기능의 개체는 내부 속성을 사용하는 경우 내부 속성 코드를 깨는, 언제든지 변경 될 수 있기 때문에
들으
가장 좋은 방법은 첫 번째 쿼리가 잘못된 데이터를 반환 한 이유를 해결하는 것입니다. 이러한 [쿼리는 필터링되지 않고 실행됩니다] (http://docs.marklogic.com/guide/performance/unfiltered#chapter) 기본적으로 필터링 된 상태로 실행하거나 인덱스를 다르게 구성하도록 설정할 수 있습니다. 잘못된 결과에 대해 더 많이 말할 수 있습니까? –
문서에 객체 배열이 있고 일치 조건이 일치하는 객체를 적어도 하나 이상 가지고있는 문서를 찾아야합니다. queryBuilder를 사용하는 경우 조건이 모든 객체의 어딘가에서 일치하는 문서를 찾습니다. 동일한 객체에있을 필요는 없습니다. 현재 queryBuilder를 사용하여 marklogic의 JSON 문서에 대해 이러한 종류의 쿼리를 수행 할 수 없습니다. XPath 쿼리를 사용하여 각 객체에 조건을 적용해야합니다. –