0

MarkLogic 版本 9.0-6.2

我需要在一个数组中接受输入(比如说 PolicyId)并返回集合中与 PolicyIds 列表匹配的所有文档。在 PolicyId 上创建了一个元素范围索引,我可以使用以下查询来执行此操作。代码按预期工作。

const PolList = ["pol1","pol2","pol3"]
cts.search(
   cts.jsonPropertyRangeQuery("RegistrationId", "=",PolList)
)

现在,我正在尝试对搜索 API (search.search) 做同样的事情。我创建了一个选项文件并部署到模块数据库

{
"options": 
  {
  "search-option": "unfiltered",
  "additional-query":[
              "<collection-query xmlns='http://marklogic.com/cts'>
              <uri>registration</uri>
              </collection-query>"
              ],
  "constraint": [
              { 
                "name": "policyId",
                "range": {
                "type": "xs:string",
                "collation" : "http://marklogic.com/collation/codepoint",
                "element": {"name": "PolicyId" }
                 }
              }
         ],
"extract-document-data": 
              {
              "selected": "all"
              }
  }
}

然后我使用下面的代码来获取文件。

const SearchOptions = fn.head(xdmp.invokeFunction(
     function() {
           return fn.doc("/Default/data-hub-FINAL/rest- 
 api/options/PolicyId.xml");
   },
   {
    'database': xdmp.database('data-hub-MODULES')
    }));

const result = fn.head(search.search('PolicyId:'+PolicyId, 
SearchOptions.firstChild)).xpath('search:result/search:extracted/data()', 
{'search': 'http://marklogic.com/appservices/search'});

此代码适用于单个 PolicyId。我如何传递一组 PolicyId 并使其工作?我想通过一个数据库调用来获取所有文档。

4

2 回答 2

0

考虑使用 cts.parse(),而不是使用 Search API,它可以将多个值绑定到标签,如PolicyId:(pol1, pol2, pol3)

有关更多信息,请参阅 cts.parse() 示例,其中包含color:(red blue)

http://docs.marklogic.com/guide/search-dev/cts_query#id_86861

此外,JSearch 还提供了用于从 SJS(服务器端 JavaScript)进行搜索的辅助函数。有关更多信息,请参阅:

http://docs.marklogic.com/guide/search-dev/javascript

于 2018-10-29T22:09:02.203 回答
0

我可以通过使用 OR 运算符来解决这个问题,如下所示。

const result = fn.head(search.search('PolicyId:'+PolicyId1 +' OR ' +PolicyId2, 
SearchOptions.firstChild)).xpath('search:result/search:extracted/data()', 
{'search': 'http://marklogic.com/appservices/search'});

我并没有完全传递一个列表,而是将输入 PolicyIds 的列表与 OR 运算符连接起来,并且能够取回所有匹配的文档。

于 2018-11-06T17:24:14.387 回答