如何在Marklogic中创建元素范围索引?

时间:2012-05-14 06:56:53

标签: xml xquery indexing marklogic

我有以下xml: -

<?xml version="1.0" encoding="UTF-8"?>
<patent-assignment>
  <assignment-record>
    <correspondent>
      <name>NORTH AMERICA INTERNATIONAL PATENT OFFIC</name>
      <address-1>P.O. BOX 506</address-1>
      <address-2>MERRIFIELD, VA 22116</address-2>
    </correspondent>
   </assignment-record>
  <patent-assignors>
    <patent-assignor>
      <name>TSAI, YU-WEN</name>
      <execution-date>
    <date>20050331</date>
      </execution-date>
    </patent-assignor>
    <patent-assignor>
      <name>HUANG, CHENG-I</name>
      <execution-date>
    <date>20050331</date>
      </execution-date>
    </patent-assignor>
  </patent-assignors>
  <patent-assignees>
    <patent-assignee>
      <name>FARADAY TECHNOLOGY CORP.</name>
      <address-1>NO.10-2, LI-HSIN ROAD 1, SCIENCE-BASED INDUSTRIAL PARK</address-1>
      <city>HSIN-CHU CITY</city>
      <country-name>TAIWAN</country-name>
    </patent-assignee>
  </patent-assignees>
 </patent-assignment>

现在我想在专利 - 转让人专利 - 受让人的名称上创建范围元素索引。但在Marklogic中,没有为范围索引指定XPath的选项。它只是将索引名称作为“名称”。那么在专利 - 转让人专利 - 受让人的名称上创建元素范围索引的正确方法是什么?

3 个答案:

答案 0 :(得分:3)

您可以将cts:path-range-query()用于专利转让人和专利受让人

  1. cts:path-range-query("/patent-assignors/patent-assignor","=",$name)
  2. cts:path-range-query("/patent-assignees/patent-assignor","=",$name)

答案 1 :(得分:2)

您无需担心元素的父元素或祖先元素。您可以通过将其包装在元素查询中来限制祖先的元素范围查询或元素值查询:

cts:element-query(xs:QName("patent-assignor"), cts:element-value-query(xs:QName("name"), "my value"))

您可以通过将序列作为第一个参数传递给cts来搜索一次调用中具有不同祖先的名称:element-query:

cts:element-query((xs:QName("patent-assignor"), xs:QName("patent-assignee")), cts:element-value-query(xs:QName("name"), "my value"))

HTH!

答案 2 :(得分:2)

Puneet,为了获得一组名称,MarkLogic需要能够以某种方式区分这些集合。最好的办法是在摄取过程中更改名称元素的localname(当前为“name”)或名称空间(当前为none)。执行此操作后,您可以构建元素范围索引并使用cts:element-values()。例如:

<?xml version="1.0" encoding="UTF-8"?>
<patent-assignment>
  <assignment-record>
    <correspondent>
      <name>NORTH AMERICA INTERNATIONAL PATENT OFFIC</name>
      <address-1>P.O. BOX 506</address-1>
      <address-2>MERRIFIELD, VA 22116</address-2>
    </correspondent>
  </assignment-record>
  <patent-assignors xmlns="http://puneet/assignors">
    <patent-assignor>
      <name>TSAI, YU-WEN</name>
      <execution-date>
        <date>20050331</date>
      </execution-date>
    </patent-assignor>
    <patent-assignor>
      <name>HUANG, CHENG-I</name>
      <execution-date>
        <date>20050331</date>
      </execution-date>
    </patent-assignor>
  </patent-assignors>
  <patent-assignees xmlns="http://puneet/assignees">
    <patent-assignee>
      <name>FARADAY TECHNOLOGY CORP.</name>
      <address-1>NO.10-2, LI-HSIN ROAD 1, SCIENCE-BASED INDUSTRIAL PARK</address-1>
      <city>HSIN-CHU CITY</city>
      <country-name>TAIWAN</country-name>
    </patent-assignee>
  </patent-assignees>
</patent-assignment>

从这个XML中,您可以在每个“name”元素上构建一个范围索引,然后调用

cts:element-values(fn:QName("http://puneet/assignees", "name"))

获取受让人的姓名。