MarkLogic TDE xpath для нескольких повторяющихся полей - PullRequest
0 голосов
/ 31 мая 2018

Мне нужно создать шаблон с использованием TDE.В конце концов я хочу иметь возможность просматривать данные в моем представлении.Проблема, которую я вижу, из-за нескольких повторяющихся элементов в моем XML.Может кто-нибудь, пожалуйста, помогите мне, как создать такой шаблон.Вот пример xml:

<entity>
  <id>id-2</id>
  <name>pub-2</name>
  <series name="s-21">s-21</series>
  <series name="s-22">s-22</series>  
  <series name="s-23">s-23</series>  
  <location>loc-1</location>
  <location>loc-2</location>    
</entity>

Я хочу увидеть 6 строк для комбинации обоих повторяемых полей, то есть серии и местоположения в этом случае.Любая помощь будет весьма заметна.

1 Ответ

0 голосов
/ 31 мая 2018

Нашел способ, используя вложенные шаблоны.Вот пример шаблона:

<template xmlns="http://marklogic.com/xdmp/tde">
  <context>entity</context>
  <rows>
    <row>
      <schema-name>main</schema-name>
      <view-name>root</view-name>
      <view-layout>sparse</view-layout>
      <columns>
        <column>
          <name>id</name>
          <scalar-type>string</scalar-type>
          <val>id</val>
        </column>
        <column>
          <name>name</name>
          <scalar-type>string</scalar-type>
          <val>name</val>
        </column>        
    </columns>
    </row>
  </rows>

  <templates>
    <template>
      <context>series</context>
      <rows>
        <row>
          <schema-name>main</schema-name>
          <view-name>series</view-name>
          <view-layout>sparse</view-layout>
          <columns>
            <column>
              <name>idParent</name>
              <scalar-type>string</scalar-type>
              <val>../id</val>              
            </column>

            <column>
              <name>series</name>
              <scalar-type>string</scalar-type>
              <val>fn:string(.)</val>
              <nullable>true</nullable>
            </column>
          </columns>
        </row>
      </rows>
    </template>
    <template>
      <context>location</context>
      <rows>
        <row>
          <schema-name>main</schema-name>
          <view-name>location</view-name>
          <view-layout>sparse</view-layout>
          <columns> 
            <column>
              <name>idParentlocation</name>
              <scalar-type>string</scalar-type>
              <val>../id</val>              
            </column>
            <column>
              <name>name</name>
              <scalar-type>string</scalar-type>
              <val>fn:string(.)</val>
              <nullable>true</nullable>
            </column>
          </columns>
        </row>
      </rows>
    </template>
  </templates>  
</template>

Вот запрос sql:

select * from main.root 
join main.location on main.location.idParentlocation = main.root.id
join main.series on main.series.idParent = main.root.id
...