我有一个包含XML文档的数据库,大致如此:
<document>
<question_item>
<question>What is your name?</question>
</question_item>
<question_item>
<question>What is your address?</question>
</question_item>
...
</document>
Run Code Online (Sandbox Code Playgroud)
我希望能够获取一个搜索词,然后返回一个明确的问题列表,其中找到该术语,例如使用上面的数据搜索"name",将返回一个结果,"你的名字是什么?".
我已经成功实现了这一点fn:distinct-values,但显然效率不高.
我想用CTS实现这个.我尝试过以下方法:
for $question in cts:element-values(
xs:QName('question'),(),(),
cts:element-word-query(xs:QName("question"), "name"))
return $question
Run Code Online (Sandbox Code Playgroud)
然而,这会导致问题在问题文本中没有"名称".例如,在上面的例子中,返回了两个问题.我认为这是因为我正在使用的查询未经过滤传递,因此如果该片段存在匹配,它将从片段返回任何问题.
这个假设是否正确?
我能做些什么才能实现我想做的事 - 有效率?
谢谢!
marklogic ×1