3

我有以下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 的选项。它只会将索引名称作为“名称”。那么在专利转让人和专利转让人的名称上创建元素范围索引的正确方法是什么?

4

3 回答 3

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)
于 2015-03-04T10:40:18.343 回答
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"))

于 2012-05-14T09:10:19.857 回答
2

Puneet,为了只获得一组名称,MarkLogic 需要能够以某种方式区分这些集合。您最好的选择是在摄取期间更改名称元素的本地名称(当前为“名称”)或名称空间(当前无)。这样做之后,您可以构建一个元素范围索引并使用 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 中,您可以在每个“名称”元素上构建范围索引,然后调用

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

获取受让人姓名。

于 2012-05-16T11:13:55.217 回答