cts:对json文档进行近查询Marklogic

问题描述

我正在使用search:像下面这样的搜索

import module namespace search = "http://marklogic.com/appservices/search"  at "/MarkLogic/appservices/search/search.xqy";

let $options :=
 
 <options xmlns="http://marklogic.com/appservices/search">
  <concurrency-level>8</concurrency-level>
  <search-option>unfiltered</search-option>
  <transform-results apply="empty-snippet">
    <!-- @apply=snippet : to get snippet-->
    <per-match-tokens>30</per-match-tokens>
    <max-matches>4</max-matches>
    <max-snippet-chars>200</max-snippet-chars>
    <preferred-matches/>
  </transform-results>
  <term>
    <term-option>case-insensitive</term-option>
    <term-option>wildcarded</term-option>
    <term-option>stemmed</term-option>
    <term-option>diacritic-insensitive</term-option>
    <term-option>punctuation-insensitive</term-option>
  </term>
  
  <constraint name="title">
    <range collation="http://marklogic.com/collation/codepoint" type="xs:string" facet="false">
      <json-property>title</json-property>
    </range>
  </constraint>    
  <extract-document-data>
    <!-- Full Title -->
    <extract-path>/title</extract-path>    
  </extract-document-data>
  
  <additional-query>
    <cts:near-query distance="1" xmlns:cts="http://marklogic.com/cts">
      <cts:json-property-word-query>
        <cts:property>title</cts:property>
        <cts:text xml:lang="en">chemotherapy</cts:text>
        <cts:option>case-insensitive</cts:option>
      </cts:json-property-word-query>
      <cts:json-property-word-query>
        <cts:property>title</cts:property>
        <cts:text xml:lang="en">hospital</cts:text>
        <cts:option>case-insensitive</cts:option>
      </cts:json-property-word-query>
      <cts:option>ordered</cts:option>
    </cts:near-query>
  </additional-query>
  <additional-query/>
</options>
return 
search:search('',$query,1,10)

使用此查询,我得到的标题是化学药品与医院之间的查询距离为1的文件

结果标题为:{“ title”:“医院癌症患者的化学疗法。”}

我做错什么了吗?

谢谢

解决方法

在Db设置中启用单词位置索引后,该功能起作用