« Übersicht: Schema

Kindelemente#

../../_images/mosaik010-potsdam.jpg

Lernziel#

Weitere Kindelemente werden hinzugefügt.

Handlungsanweisungen#

Aufgaben:
  1. Erweitern Sie das Schema aus der vorherigen Station

  2. Fügen Sie ein zweites Element anrede ein.

  3. Wiederholen Sie die Arbeitsschritte für das Element postanschrift, so wie es für das Element name demonstriert ist.

Die DTD als Vorlage#

Zeilen: 6, 8, 9

 1<?xml version="1.0" encoding="UTF-8"?>
 2<!ELEMENT adressdb (adresse+)>
 3<!ENTITY % sichtbarkeit "einsicht (privat|public|proteced) #REQUIRED">
 4<!ELEMENT adresse (anrede, name, strasse, postanschrift, email?, bild)>
 5<!ELEMENT anrede (#PCDATA)>
 6<!ELEMENT name (nachname, vorname)>
 7<!ELEMENT postanschrift (plz, wohnort)>
 8<!ELEMENT nachname (#PCDATA)>
 9<!ELEMENT vorname (#PCDATA)>
10<!ELEMENT plz (#PCDATA)>
11<!ELEMENT wohnort (#PCDATA)>
12<!ELEMENT strasse (#PCDATA) >
13<!ELEMENT email (#PCDATA)>
14<!ATTLIST strasse %sichtbarkeit;>
15<!ATTLIST postanschrift land
16          (Deutschland | Schweiz | Oesterreich) #REQUIRED %sichtbarkeit; >
17<!ATTLIST adresse nr CDATA #REQUIRED>
18<!ELEMENT bild EMPTY>
19<!ATTLIST bild bezeichnung CDATA #REQUIRED>
20<!ENTITY email_default "keine E-Mail angegeben" %sichtbarkeit; >

Kind-Elemente in der DTD#

<!ELEMENT name (nachname, vorname)>
<!ELEMENT nachname (#PCDATA)>
<!ELEMENT vorname (#PCDATA)>

ComplexType als Container#

Zeilen: 25-32, 37-38

 1<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
 2  <xs:element name="adressdb">
 3    <xs:annotation>
 4      <xs:documentation>Meine Adressammlung</xs:documentation>
 5    </xs:annotation>
 6    <xs:complexType>
 7      <xs:sequence>
 8        <xs:element ref="adresse" minOccurs="1" maxOccurs="unbounded"/>
 9      </xs:sequence>
10    </xs:complexType>
11  </xs:element>
12  <xs:element name="adresse">
13    <xs:complexType>
14      <xs:sequence>
15        <xs:element ref="anrede" minOccurs="1"/>
16        <xs:element ref="name" minOccurs="1"/>
17        <xs:element ref="strasse" minOccurs="1"/>
18        <xs:element ref="postanschrift" minOccurs="1"/>
19        <xs:element ref="email" minOccurs="0"/>
20        <xs:element ref="bild" minOccurs="1"/>
21      </xs:sequence>
22    </xs:complexType>
23  </xs:element>
24  <xs:element name="anrede" type="xs:string"/>
25  <xs:element name="name">
26    <xs:complexType>
27      <xs:sequence>
28        <xs:element ref="nachname"/>
29        <xs:element ref="vorname"/>
30      </xs:sequence>
31    </xs:complexType>
32  </xs:element>
33  <xs:element name="strasse" type="xs:string"/>
34  <xs:element name="postanschrift" type="xs:string"/>
35  <xs:element name="email" type="xs:string"/>
36  <xs:element name="bild" type="xs:string"/>
37  <xs:element name="nachname" type="xs:string"/>
38  <xs:element name="vorname" type="xs:string"/>
39</xs:schema>

Aus einem einfachen Datentyp kann ein complexType erzeugt werden, wie hier am Beispiel von name mit den neuen Kindelementen vorname und nachname demonstriert wird.

Das fertige XML-Dokument#

<?xml version="1.0" encoding="UTF-8"?>
<adressdb xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
          xsi:noNamespaceSchemaLocation="art03.xsd">
  <adresse>
    <anrede/>
    <name>
      <nachname/>
      <vorname/>
    </name>
    <strasse/>
    <postanschrift/>
    <bild/>
  </adresse>
</adressdb>