Guide: XML (XML Schema XSD – Teil 2)

4.2.2.3 Definition von Typen

Jedem Element und Attribut werden Typen zugeordnet. In der XSD gibt es einfache (“simpleType”) und komplexe(“complexType”) Typen.

Einfache Typen “simpleType”:

Der “simpleType” definiert einen einfachen Typ, welcher bereits vordefinierte Typen, wie z.B. xsd:string, xsd:int etc. enthält.

Es ist auch möglich, eigene einfache Typen zu schaffen, allerdings müssen diese auf einfachen, schon vordefinierten Typen bestehen und diese einschränken.

Beispiel in XSD:
<?xml version=”1.0” encoding=”UTF-8”?>
<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema">
...
<xsd:simpleType name="waehrung">
   <xsd:restriction base=”xsd:string”>
            <!--Facette -->
   </xsd:restriction>
   </xsd:simpleType>
</xsd:schema>

 

In dem Falle haben wir einen einfachen Typ namens “waehrung” geschaffen, welcher über xsd:restriction Beschränkungen enthält, allerdings basiert (“base”) dieser Typ “waehrung” auf den vordefinierten Typ “xsd:string”, wobei dann durch so genannte Facetten die Beschränkung erfolgt.

 

Komplexe Typen “complexType”:

Komplexe Datentypen erlauben in XML die Kindelemente eines Elementes zu beschreiben.

Beispiel:
<xsd:element name="Name" type=”name”>
   <xsd:complexType>
      <xsd:sequence>
         <xsd:element name="Vorname" type="xsd:string"/>
         <xsd:element name="Nachname" type="xsd:string"/>
        </xsd:sequence>
   </xsd:complexType>
</xsd:element>

Hiermit weise ich dem Element “Name” den Typ “Name” zu. Da es diesen Datentyp noch nicht gibt, muss er erst beschrieben werden, welche Elemente er enthält.

Das hier angegebene Beispiel bedeutet, dass das Element “Name”, 2 Kindelemente hat.

Einfacher Inhalt “simpleContent”:

Der “simpleContent” definiert einen einfachen Inhalt, was bedeutet, dass er nur Text enthalten darf.

Komplexer Inhalt “complexContent”:

Der “complexContent” definiert einen komplexen Inhalt, was bedeutet, dass er Text, Attribute und andere Elemente enthalten darf.

 

4.2.2.4 Definition des Inhaltes

 

4.2.2.4.1 Sequenz

Merkmale:

  • Elemente müssen der Reihe nach vorkommen.
  • Falls keine anderen Werte angegeben werden, können Elemente 0 oder mehrfach vorkommen.
Beispiel:
<xsd:element name="Anschrift" type=”anschrift”>
   <xsd:complexType name=”anschrift”>
      <xsd:sequence>
         <xsd:element name="wohnort" type="xsd:string"/>
         <xsd:element name="plz" type="xsd:int"/>
         <xsd:element name="strasse" type="xsd:string"/>
         <xsd:element name="nr" type="xsd:int"/>
         <xsd:element name="name" type="xsd:string"/>
        </xsd:sequence>
   </xsd:complexType>
</xsd:element>

 

4.2.2.4.2 Choice

Merkmale:

  • Aus einer Anzahl von Elementen darf, falls kein anderer Wert über Max/MinOccurs gesetzt, ein Element vorkommen. Ansonsten auch mehrere möglich.
  • Reihenfolge beliebig.
  • Durch das MaxOccurs ist es möglich zu sagen, dass Elemente mehrfach und die Reihenfolge beliebig ist
Beispiel:
<xsd:element name="Tier" type=”tier”>
   <xsd:complexType name=”tier”>
      <xsd:choice>
         <xsd:element name="Affe" type="xsd:string"/>
         <xsd:element name="Tiger" type="xsd:string "/>
         <xsd:element name="Leopard" type="xsd:string"/>
         <xsd:element name="Maus" type="xsd:string "/>
        </xsd:choice>
   </xsd:complexType>
</xsd:element>
4.2.2.4.3 All

Merkmale:

  • Jedes Element darf einmal vorkommen.
  • Reihenfolge spielt keine Rolle.
Beispiel:
<xsd:element name="Einkaufsliste" type=”einkaufsliste”>
   <xsd:complexType name=”einkaufsliste”>
      <xsd:all>
         <xsd:element name="Kaese" type="xsd:string"/>
         <xsd:element name="Milch" type="xsd:string "/>
         <xsd:element name="Butter" type="xsd:string"/>
         <xsd:element name="Wurst" type="xsd:string "/>
        </xsd:all>
   </xsd:complexType>
</xsd:element>

 

4.2.2.4.4 Group

Merkmale:

  • Gruppiert eine Reihe von Elementen oder Anweisungen.
Beispiel:
<xsd:complexType name="BestellungTyp">
  <xsd:sequence>
    <xsd:choice>
      <xsd:group ref="verschiedeneAdr"/>
      <xsd:element name="eineAdresse" type="DeAdresse"/>
    </xsd:choice>
    <xsd:element ref="Kommentar" minOccurs="0"/>
    <xsd:element name="Waren" type="WarenTyp"/>
  </xsd:sequence>
  <xsd:attribute name="bestelldatum" type="xsd:date"/>
</xsd:complexType>

<xsd:group name="verschiedeneAdr">
  <xsd:sequence>
    <xsd:element name="Lieferadresse" type="DeAdresse"/>
    <xsd:element name="Rechnungsadresse" type="DeAdresse"/>
  </xsd:sequence>
</xsd:group>

 

4.2.2.4.5 Any

Merkmale:

  • Erlaubt beliebigen Datentyp
4.2.2.4.6 Extensions

Extension bedeutet auf Deutsch Ableitung. Das Prinzip was dahinter steckt, ist bereits aus der Programmierung bekannt – Stichwort lautet Vererbung.

Ableitungen von Elementtypen sind dann interessant, wenn man manche Elemente spezialisieren möchte. Man spart sich dadurch eine Menge Tipparbeit und man kann einfach andere Kindelemente an das Elternelement dranhängen. Als Beispiel möchte ich hier die Einkaufsliste erweitern.

Beispiel:
<xsd:complexType name=”myEinkaufsliste”>
   <xsd:complexContent>
      <xsd:extension base=”einkaufsliste”>
         <xsd:all>
         <xsd:element name="Fertigesssen" type="xsd:string"/>
           </xsd:all>
      </xsd:extension>
   </xsd:complexContent>
</xsd:complexType>

 

4.2.2.4.7 Restrictions

Man kann auch einen neuen Elementtypen erzeugen, indem man einen bereits vorhandenen Elementtyp beschränkt. Dafür müssen alle Elemente aufgezählt werden und dabei kann man beliebig die Beschränkungen verteilen.

Als Beispiel möchte ich mein Anschriftsschema von oben verwenden.

Beispiel:
<xsd:complexType name=”singelAnschrift”>
   <xsd:restriction base="anschrift">
      <xsd:sequence>
         <xsd:element name="wohnort" type="xsd:string"/>
         <xsd:element name="plz" type="xsd:int"/>
         <xsd:element name="strasse" type="xsd:string"/>
         <xsd:element name="nr" type="xsd:int"/>
         <xsd:element name="name" type="xsd:string" minOccurs=”1” maxOccurs=”1”/>
        </xsd:sequence>
   </xsd:restriction>
</xsd:complexType>

Bei dem Beispiel muss immer ein Element “name” vorkommen.

Liste der Einschränkungen, auch Facetten genannten, durch welche man einfache Beschränkungen realisieren kann:

  • length, maxLength, minLength – Länge eines Strings
  • enumeration – Auswahl
  • pattern – Reguläre Ausdrücke
  • minExclusiv, maxExclusiv, minInclusiv, maxInclusiv – Wertebereicheinschränkung
  • totalDigits, fractionDigits – Einschränkung der Dezimalstelle (Gesamtzahl, Nachkommastelle)
  • whiteSpace – Behandlung von Tabs und Leerzeichen
Beispiel:
<xsd:simpleType name=”IQ”>
   <xsd:restriction base="xsd:decimal">
      <xsd:minInclusiv value=”80”/>
      <xsd:maxInclusiv value="180"/>
      <xsd:fractionDigits value=”3”/>
   </xsd:restriction>
</xsd:simpleType>

 

4.2.2.4.8 List

In einem XML Element können durch den Typ Liste mehrere “pseudo”-Elemente drin stehen. Die Elemente müssen allerdings alle vom selben Typ sein.

Beispiel:
<xsd:simpleType name="BundeslandListe">
    <xsd:list itemType="Bundesland"/>
</xsd:simpleType>

<xsd:simpleType name="SechsBundesländer">
    <xsd:restriction base="BundeslandListe">
    <xsd:length value="6"/>
    </xsd:restriction>
</xsd:simpleType>

Beispiel:
<sechsLänder>Sachsen       Baden-Württemberg   Rheinland-Pfalz
             Brandenburg   Niedersachsen       Hessen</sechsLänder>

 

4.2.2.4.9 Union

Die Union bietet in der XSD die Möglichkeit einem Element mehrere Typen zu geben, sodass man ähnlich zur Liste, mehrere “pseudo” Elemente in einem Tag hat.

Syntax: <xsd:union memberTypes=”Typen” />

Beispiel:
<xsd:simpleType name="Irgendwas">
   <xsd:union memberTypes="xsd:int xsd:string"/>
</xsd:simpleType>

Beispiel:
<Irgendwas>12 Bla</Irgendwas>
<Irgendwas>12</Irgendwas>
<Irgendwas>12 Bla 12</Irgendwas>
<Irgendwas>Bla Bla</Irgendwas>

 

4.2.2.4.10 AnyAttribute

Erlaubt beliebige Attribute innerhalb von Elementen.

4.2.2.4.11 AttributeGroup

Gruppiert Attribute, sodass ein einfacher Zugriff auf diese möglich ist.

 

Letzte Posts

  • image.png
    RavenHQ–RavenDB in der Cloud

    Ayende Rahien hat es heute verkündet – RavenHQ, der RavenDB Cloud Hoster (natürlich von und mit Ayende) ist ab heute raus aus der Beta und man kann es von überall aus nutzen. In der Betaphase waren nur Nutzer von AppHarbor zugelassen. Was ist RavenHQ? RavenHQ ist im Grunde ein gehostes RavenDB in den Rechenzentren von ...

  • image.png
    GitHub for Windows–erste Eindrücke

    Git ist schon eine tolle Sachen und eröffnet viele neue Möglichkeiten – allerdings ist der Einstieg recht hart und selbst wenn man die guten Hilfsanleitungen auf GitHub befolgt, kommt man am Anfang nur langsam vorwärt. Insbesondere ist das Tooling für Windows / .NET Entwickler auch nicht gerade “bekanntes Terrain”. GitHub to the rescue! Die GitHub ...

  • image.png
    Chocolatey–apt-get für Windows

    Durch Zufall bin ich auf das Tool “Chocolatey” gestoßen. Wer die Website sich anschaut, wird evtl. eine Verwandschaft mit NuGet ausmachen. Was macht Chocolatey? Chocolatey ist ein “Maschine Package Manager”, das bedeutet, dass man für seine Maschine einfach Tools runterladen und Updaten kann – direkt über die Konsole. Was ist der Unterschied zu NuGet? NuGet ...

  • image.png
    SASS, LESS & Coffeescript in Visual Studio mit der Web Workbench

    CSS und Javascript sind die “kleinste” Schnittmenge von allen Browsern für die Erstellung von Web-Applikationen. Leider geht dabei etwas komfort verloren, daher lieben alle Webentwickler jQuery! SASS und LESS sind zwei Varianten, wie man “schöner” CSS schreiben kann und Coffeescript versucht Javascript Entwicklung zu vereinfachen. Aber immer der Reihe nach… Was ist SASS? SASS steht ...

  • image.png
    Code-Inside Sample nun auf GitHub: Google Code zu GitHub Migration

    Seit einiger Zeit habe ich Beispielcode auf Google Code bereitgestellt. Einfach nur noch weg von Google Code O-Ton damals war: Ich hatte mich für Google Code entschieden, weil ich hoffe dass früher oder später die Google Code Suche nutzbar ist und es dadurch wenigstens ein kleiner Mehrwert entsteht. Allerdings wirft es momentan noch ein Fehler. ...

Support us!