XSD: sequence bzw. all Reihenfolge
    
LeKuchen
    
    
      
    
  - xml
 
Hallo zusammen,
ich habe ein XML Schema, welches eine Person beschreibt (s.u.).
In dem Element "Person" soll unter einem Data-Node eine beliebige Anzahl von Items und Collections in beliebiger Reihenfolge enthalten sein können. (Gemischt Item und Collection!)
Mit "sequence" müssen aber erst die Item-Elemente und dann die Collection-Elemente gelistet sein. Mit "all" hingegen ist die Reihenfolge beliebig, es kann aber nur jeweils ein Item-Element und ein Collection-Element enthalten sein.
Gibt es da eine Kombination von beidem oder einen Workaround?
Gruß
LeKuchen
Element Person mit xmlns:xs="http://www.w3.org/2001/XMLSchema":
<xs:complexType name="Person">
    xs:sequence
      <xs:element name="Data" maxOccurs="1" minOccurs="1">
        xs:complexType
          xs:sequence
            <xs:element name="Item" type="itm:Item" maxOccurs="unbounded" />
            <xs:element name="Collection" type="itm:Collection" maxOccurs="unbounded" />
          </xs:sequence>
          <xs:attribute name="id" type="xs:integer" use="required" />
          <xs:attribute name="dbrelation" type="xs:string" use="required" />
          <xs:attribute name="createDate" type="xs:dateTime" use="required" />
          <xs:attribute name="updateDate" type="xs:dateTime" use="required" />
        </xs:complexType>
      </xs:element>
Es wird referenziert auf Item und Collection:
<xs:complexType name="Collection">
    xs:sequence
      <xs:element name="label" type="xs:string" minOccurs="0" maxOccurs="1" />
      <xs:element name="Data" minOccurs="0" maxOccurs="unbounded">
        xs:complexType
          xs:sequence
            <xs:element name="Item" type="itm:Item" maxOccurs="unbounded" />
          </xs:sequence>
          <xs:attribute name="createDate" type="xs:dateTime" use="required" />
          <xs:attribute name="updateDate" type="xs:dateTime" use="required" />
        </xs:complexType>
      </xs:element>
    </xs:sequence>
    <xs:attribute name="id" type="xs:integer" />
    <xs:attribute name="dbrelation" type="xs:string" />
  </xs:complexType>
  <xs:complexType name="Item">
    xs:sequence
      <xs:element name="label" type="xs:string" minOccurs="1" maxOccurs="1" />
      <xs:element name="value" type="xs:string" minOccurs="1" maxOccurs="1" />
      <xs:element name="text" type="xs:string" minOccurs="0" maxOccurs="1" />
    </xs:sequence>
    <xs:attribute name="id" type="xs:integer" use="required" />
    <xs:attribute name="dbname" type="xs:string" use="required" />
    <xs:attribute name="dbtype" type="xs:string" use="required" />
    <xs:attribute name="length" type="xs:integer" use="optional" />
  </xs:complexType>
Tach LeKuchen,
Mit "sequence" müssen aber erst die Item-Elemente und dann die Collection-Elemente gelistet sein. Mit "all" hingegen ist die Reihenfolge beliebig, es kann aber nur jeweils ein Item-Element und ein Collection-Element enthalten sein.
Gibt es da eine Kombination von beidem oder einen Workaround?
Theoretisch mit xs:choice statt xs:sequence, was aber praktisch auf ein nicht-deterministisches Inhaltsmodell hinausläuft, d. h. der Parser kann nicht vorrausschauend ermitteln, welches Element in der Folge erwartet wird. Da solche Strukturen eher für Datenchaos statt -ordnung sprechen, versuche es mit einem anderen Aufbau.
Man liest sich,
svg4you
Hallo svg4you,
Theoretisch mit xs:choice statt xs:sequence, was aber praktisch auf ein nicht-deterministisches Inhaltsmodell hinausläuft, d. h. der Parser kann nicht vorrausschauend ermitteln, welches Element in der Folge erwartet wird. Da solche Strukturen eher für Datenchaos statt -ordnung sprechen, versuche es mit einem anderen Aufbau.
Hmm, mit xs:choice ist dann soweit ich es sehe nur entweder Item oder Collection möglich, und nicht gemischt.
Ich verstehe Deine Vorbehalte gegen diese Datenstruktur - ist aber leider genauso beabsichtigt um das System flexibel zu machen. Die XSD soll als Vorlage für eine WSDL-Datei dienen. Dabei soll das zu übertragende Datenset beliebig erweiterbar sein.
Gruß
LeKuchen
Tach LeKuchen,
Ich verstehe Deine Vorbehalte gegen diese Datenstruktur - ist aber leider genauso beabsichtigt um das System flexibel zu machen. Die XSD soll als Vorlage für eine WSDL-Datei dienen. Dabei soll das zu übertragende Datenset beliebig erweiterbar sein.
Im Grunde läuft es doch auf (zunächst) diese DTD hinaus:
  
<!ELEMENT wurzel (a+)>  
<!ELEMENT a ((b|c)*,(c|b)*)>  
<!ELEMENT b (#PCDATA)>  
<!ELEMENT c (#PCDATA)>
oder alternativ auf dieses Schema:
  
<?xml version="1.0" encoding="ISO-8859-1"?>  
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">  
  
  <xs:element name="wurzel">  
    <xs:complexType>  
      <xs:sequence>  
        <xs:element ref="a" minOccurs="1" maxOccurs="unbounded"/>  
      </xs:sequence>  
    </xs:complexType>  
  </xs:element>  
  
  <xs:element name="a">  
    <xs:complexType>  
      <xs:sequence>  
        <xs:choice minOccurs="0" maxOccurs="unbounded">  
          <xs:element ref="b"/>  
          <xs:element ref="c"/>  
        </xs:choice>  
        <xs:choice minOccurs="0" maxOccurs="unbounded">  
          <xs:element ref="c"/>  
          <xs:element ref="b"/>  
        </xs:choice>  
      </xs:sequence>  
    </xs:complexType>  
  </xs:element>  
  
  <xs:element name="b">  
    <xs:complexType mixed="true"/>  
  </xs:element>  
  
  <xs:element name="c">  
    <xs:complexType mixed="true"/>  
  </xs:element>  
  
</xs:schema>
und diese Strukturen sind eben nicht-deterministisch. Kommt ggf. darauf an, was der Parser daraus macht.
Man liest sich,
svg4you