MENU
XSD
XML Schema Definition, or W3C XML Schema (WXS), is XML-based. All its elements can have the ‘id’ attribute as well as other attributes. The name of a XSD file ends with “.xsd”.Instead of coding an XSD file from scratch, you can use the XSD inference tool in XMLSpy or OxygenXML to generate an XSD file from an XML file. Such a tool can also be found in Microsoft’s XML Schema Definition Tool (XSD.exe), Apache’s XMLBeans, Trang, xmlgrid.net etc.
This illustrates the basic features of XSD. |
<?xml version="1.0"?> <zoo xmlns="http://www.example.com" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.example.com zoo.xsd"> <animal id="l123444"> <name>Mighty</name> <type>lion</type> <kg>135</kg> <imported/> </animal> <animal id="b355345"> <name>Lucky</name> <type>bear</type> <kg>205</kg> </animal> </zoo> |
<?xml version="1.0"?> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="http://www.example.com" xmlns="http://www.example.com" elementFormDefault="qualified"> <xs:element name="zoo"><xs:complexType><xs:sequence> <xs:element name="animal" maxOccurs="unbounded"> <xs:complexType> <xs:sequence> <xs:element name="name" type="xs:string"/> <xs:element name="type"><xs:simpleType> <xs:restriction base="xs:string"> <xs:enumeration value="lion"/> <xs:enumeration value="bear"/> <xs:enumeration value="tiger"/> </xs:restriction> </xs:simpleType></xs:element> <xs:element name="kg"><xs:simpleType> <xs:restriction base="xs:integer"> <xs:minInclusive value="10"/> <xs:maxInclusive value="5000"/> </xs:restriction> </xs:simpleType></xs:element> <xs:element name="imported" minOccurs="0"> <xs:complexType/> </xs:element> </xs:sequence> <xs:attribute name="id" type="xs:string"/> </xs:complexType> </xs:element> </xs:sequence></xs:complexType></xs:element> </xs:schema> |
schama can have the following attributes:
|
element and attribute can have the following attributes:
|
attribute can have the following attribute:
|
complexType can have the following attributes:
|
If an attribute or element does not have the ‘type’ attribute, its type must be declared as its child element. |
You can specify multiple XSD files in the XML file like this: <ns1:root xmlns:ns1="http://example.com/1" xmlns:ns2="http://example.com/2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://example.com/1 ns1.xsd http://example.com/2 ns2.xsd"> <ns2:a/> </ns1:root> |
Elements Hierarchy (simplified) |
schema group, attributeGroup redefine notation import include element alternative simpleType union list restriction (assert) enumeration fractionDigits length {max|min}Exclusive {max|min}Inclusive {max|min}Length pattern totalDigits whitespace complexType openContent sequence, choice, all (element) (group) any attribute, anyAttribute (group), (attributeGroup) simpleContent, complexContent (restriction) (assert) extension (assert) assert unique,key,keyref selector field annotation appinfo documentation |
(schema is always the document root.) (annotation can be the child of any element.) (simpleType can be a child of attribute, element, list, restriction, schema, and union.) (complexType can be a child of element, redefine, and schema.) (attribute can be a child of attributeGroup, schema, complexType, restriction (both simpleContent and complexContent), and extension (both simpleContent and complexContent).) (anyAttribute can be a child of complexType, restriction (both simpleContent and complexContent), and extension (both simpleContent and complexContent), attributeGroup.) (group can be a child of schema, choice, sequence, all, complexType, restriction (both simpleContent and complexContent), and extension (both simpleContent and complexContent).) (attributeGroup can be a child of attributeGroup, complexType, schema, restriction (both simpleContent and complexContent), and extension (both simpleContent and complexContent).) (sequence and choice can be a child of group, choice, sequence, complexType, restriction (both simpleContent and complexContent), extension (both simpleContent and complexContent).) (all can be a child of group, complexType, restriction (both simpleContent and complexContent), and extension (both simpleContent and complexContent).) (restriction can be a child of simpleType, simpleContent, and complextContent.) |
sequence means that the child elements must appear in the specified order, each occurring one time. choice means that only one of the child elements can appear. all means that the child elements can appear in any order, each occurring one time. |
For element, sequence, choice, all, any, or group, you can specify the ‘minOccurs’ and ‘maxOccurs’ attributes, which dictate the minimum and maximum numbers of times an element (or group of elements) can appear. |
This uses assertions to deny certain attribute and element values, as well as to validate the order of the attribute values. |
<?xml version="1.0" encoding="UTF-8"?> <Transactions xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="transactions.xsd"> <Transaction OrderID="50">-1000</Transaction> <Transaction OrderID="60">1000</Transaction> <Transaction OrderID="70">3000</Transaction> <Transaction OrderID="300">2000</Transaction> </Transactions> |
<?xml version="1.0" encoding="UTF-8"?> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"> <xs:element name="Transactions"> <xs:complexType> <xs:sequence> <xs:element name="Transaction" maxOccurs="unbounded"> <xs:complexType> <xs:simpleContent> <xs:extension base="xs:integer"> <xs:attribute name="OrderID" type="xs:integer"/> <xs:assert test= "empty(index-of((8,9,10),@OrderID))"/> <xs:assert test= "$value = (-3000 to 3000)"/> </xs:extension> </xs:simpleContent> </xs:complexType> </xs:element> </xs:sequence> <xs:assert test="every $x in Transaction satisfies (empty($x/preceding-sibling::*) or ($x/@OrderID gt $x/preceding-sibling::*[1]/@OrderID))"/> </xs:complexType> </xs:element> </xs:schema> |
The value for the ‘test’ attribute in assert is an XPath. |
This illustrates how to use annotations, groups, references, and restrictions. |
<?xml version="1.0"?> <dictionary xmlns="http://www.example.com" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.example.com dictionary.xsd"> <word id="w5445353" initial="b"> <spelling>beautiful</spelling> <type>adjective</type> </word> <word id="w1222234" initial="t"> <spelling>table</spelling> <type form="singular">noun</type> </word> </dictionary> |
<?xml version="1.0"?> <!-- dictionary.xsd --> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="http://www.example.com" xmlns="http://www.example.com" elementFormDefault="qualified"> <xs:include schemaLocation="dictDef.xsd"/> <xs:element name="dictionary" type="dType"/> </xs:schema> |
<?xml version="1.0"?> <!-- dictDef.xsd --> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="http://www.example.com" xmlns="http://www.example.com" elementFormDefault="qualified"> <xs:annotation> <xs:appinfo source=”http://example.com/info/”> Example Note </xs:appinfo> <xs:documentation source=”http://example.com/info/”> A group, attribute group, or custom type may be reused multiple times. </xs:documentation> </xs:annotation> <xs:simpleType name="wType"> <xs:restriction base="xs:string"> <xs:enumeration value="noun"/> <xs:enumeration value="verb"/> <xs:enumeration value="adjective"/> </xs:restriction> </xs:simpleType> <xs:group name="wSequence"> <xs:sequence> <xs:element name="spelling"><xs:simpleType> <xs:restriction base="xs:string"> <xs:pattern value="[a-zA-Z ]+"/> <xs:maxLength value="50"/> <xs:whiteSpace value="collapse"/> </xs:restriction> </xs:simpleType></xs:element> <xs:element name="type"> <xs:complexType><xs:simpleContent> <xs:extension base="wType"> <xs:attribute name="form"> <xs:simpleType> <xs:restriction base="xs:string"> <xs:enumeration value="singular"/> <xs:enumeration value="plural"/> <xs:enumeration value="present"/> <xs:enumeration value="past"/> </xs:restriction> </xs:simpleType> </xs:attribute> </xs:extension> </xs:simpleContent></xs:complexType> </xs:element> </xs:sequence> </xs:group> <xs:attributeGroup name="wAttributes"> <xs:attribute name="id" type="xs:ID" /> <xs:attribute name="initial" type="xs:NMTOKEN" /> <xs:anyAttribute/> </xs:attributeGroup> <xs:complexType name="dType"><xs:sequence> <xs:element name="word" maxOccurs="999999"> <xs:complexType> <xs:group ref="wSequence"/> <xs:attributeGroup ref="wAttributes"/> </xs:complexType> </xs:element> </xs:sequence></xs:complexType> </xs:schema> |
Here we custom-define a simple data type, a complex data type, a group of elements, and a group of attributes to be used later. |
element and attribute can have the attribute 'rel’. |
include adds an external XSD schema with the same target namespace. To add a schema with a different target namespace, use import: <xs:import namespace="http://example.com/schema"/> <xs:import schemaLocation="http://example.com/schema"/> |
For restriction and extension, you must specify the base attribute, which can be either a built-in primitive data type or a custom data type. |
You can’t include both a restriction and an extension within complexType. If you wish to restrict and declare an attribute for an element at the same time, you must first declare a restricted simpleType, and use that type as the base for the extension of the element. |
anyAttribute allows the element to include attributes not declared by the schema. |
complexContent contains an extension or a restriction for a complexType. simpleContent contains an extension or a restriction for a simpleType, or for a complexType containing text only. |
This demonstrates conditional type assignment, in which the type of an element depends on one of its attributes. This also shows how to specify XSD versions for the validator. |
<?xml version="1.0" encoding="UTF-8"?> <integer xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "file:///C:/Zend/Apache2/htdocs/xml/integer.xsd" kind="b">127</integer> |
<?xml version="1.0" encoding="UTF-8"?> <xs:schema xmlns:xs= "http://www.w3.org/2001/XMLSchema" xmlns:vc= "http://www.w3.org/2007/XMLSchema-versioning" elementFormDefault="qualified" attributeFormDefault="unqualified" vc:minVersion="1.1"> <xs:complexType name="bInt"> <xs:simpleContent> <xs:extension base="xs:byte"> <xs:attribute name="kind" type="xs:string"/> </xs:extension> </xs:simpleContent> </xs:complexType> <xs:complexType name="sInt"> <xs:simpleContent> <xs:extension base="xs:short"> <xs:attribute name="kind" type="xs:string"/> </xs:extension> </xs:simpleContent> </xs:complexType> <xs:complexType name="iInt"> <xs:simpleContent> <xs:extension base="xs:int"> <xs:attribute name="kind" type="xs:string"/> </xs:extension> </xs:simpleContent> </xs:complexType> <xs:complexType name="lInt"> <xs:simpleContent> <xs:extension base="xs:long"> <xs:attribute name="kind" type="xs:string"/> </xs:extension> </xs:simpleContent> </xs:complexType> <xs:complexType name="gInt"> <xs:simpleContent> <xs:extension base="xs:integer"> <xs:attribute name="kind" type="xs:string"/> </xs:extension> </xs:simpleContent> </xs:complexType> <xs:element name="integer" vc:minVersion="1.1" vc:maxVersion="3.0"> <xs:alternative test="@kind='b'" type="bInt"/> <xs:alternative test="@kind='s'" type="sInt"/> <xs:alternative test="@kind='i'" type="iInt"/> <xs:alternative test="@kind='l'" type="lInt"/> <xs:alternative type="gInt"/> </xs:element> </xs:schema> |
This illustrates notation, list, union, dateTime, and numeric restrictions. |
<?xml version="1.0"?> <dtList xmlns="http://www.example.com" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.example.com date.xsd"> 2013-03-02Z 12:00:00+08:00 2013-03-02T12:00:00+08:00 123 321.444 </dtList> |
<?xml version="1.0"?> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="http://www.example.com" xmlns="http://www.example.com" elementFormDefault="qualified"> <xs:notation name="jpeg" public="image/jpeg" system="viewer.exe" /> <xs:simpleType name="numbers"> <xs:restriction base="xs:decimal"> <xs:totalDigits value="10"/> <xs:fractionDigits value="3"/> </xs:restriction> </xs:simpleType> <xs:simpleType name="dUnion"> <xs:union memberTypes="xs:date xs:time xs:dateTime numbers"/> </xs:simpleType> <xs:element name="dtList"> <xs:simpleType> <xs:list itemType="dUnion"/> </xs:simpleType> </xs:element> </xs:schema> |
totalDigits specifies the maximum number of digits allowed. fractionDigits specifies the maximum number of digits allowed after the decimal point. |
This shows how to declare any element, notation, and ‘mixed’ content. Here, <nameslist> must start with one single arbitrary element. An element named <description> must appear after another element named <name>, with any number of arbitrarily named elements in between. |
<?xml version="1.0" encoding="UTF-8"?> <nameslist xmlns="http://www.example.com" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.example.com nameslist.xsd"> <group>Famous People</group> <person> <name>Bruce</name> <age>30</age> <description>He is a real <b>fighter</b>.</description> </person> <person> <name>Stephen</name> <sex>male</sex> <status>married</status> <description>He is a real <b>writer</b>.</description> </person> </nameslist> |
<?xml version="1.0"?> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns="http://www.example.com" targetNamespace="http://www.example.com" elementFormDefault="qualified"> <xs:notation name="jpeg" public="image/jpeg" system="viewer.exe" /> <xs:element name="nameslist"> <xs:complexType> <xs:sequence> <xs:any namespace="##any" processContents="lax" notQName="name description person"/> <xs:element name="person" maxOccurs="10"> <xs:complexType> <xs:openContent> <xs:any namespace="##any" processContents="lax"/> </xs:openContent> <xs:sequence> <xs:element name="name" type="xs:string"/> <xs:element name="description"> <xs:complexType mixed="true"> <xs:sequence> <xs:element name="b" type="xs:string"/> </xs:sequence> </xs:complexType> </xs:element> </xs:sequence> </xs:complexType> </xs:element> </xs:sequence> </xs:complexType> </xs:element> </xs:schema> |
Group references are allowed in all model groups. |
A notation describes the format of non-XML data. |
A complexType or complexContent with the mixed attribute declared as ‘true’ can have text around its child elements, ie. a mixture of elements and text. |
openContent can have the ‘mode’ attribute, which can have a value of ‘none’, ‘interleave’, or ‘suffix’. The default is ‘interleave’. |
any and anyAttribute can have the following attributes:
|
redefine allows you to redefine simple and complex types, groups and attribute groups from an external schema. This construct is deprecated in XSD 1.1. |
<?xml version="1.0"?> <item xmlns="http://www.example.com" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.example.com item.xsd"> <name>ruler</name> <price>1.00</price> </item> |
<?xml version="1.0"?> <!-- item.xsd --> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="http://www.example.com" xmlns="http://www.example.com" elementFormDefault="qualified"> <xs:redefine schemaLocation="item2.xsd"> <xs:complexType name="iDetails"> <xs:complexContent> <xs:extension base="iDetails"> <xs:sequence> <xs:element name="price"/> </xs:sequence> </xs:extension> </xs:complexContent> </xs:complexType> </xs:redefine> <xs:element name="item" type="iDetails"/> </xs:schema> |
<?xml version="1.0"?> <!-- item2.xsd --> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="http://www.example.com" xmlns="http://www.example.com" elementFormDefault="qualified"> <xs:complexType name="iDetails"> <xs:sequence> <xs:element name="name"/> </xs:sequence> </xs:complexType> </xs:schema> |
Rather similar to redefine is override. |
<?xml version="1.0"?> <item xmlns="http://www.example.com" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.example.com item.xsd"> <price>1.00</price> </item> |
<?xml version="1.0"?> <!-- item.xsd --> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns="http://www.example.com" targetNamespace="http://www.example.com" elementFormDefault="qualified"> <xs:override schemaLocation="item2.xsd"> <xs:complexType name="iDetails"> <xs:sequence> <xs:element name="price"/> </xs:sequence> </xs:complexType> </xs:override> <xs:element name="item" type="iDetails"/> </xs:schema> |
<?xml version="1.0"?> <!-- item2.xsd --> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns="http://www.example.com" targetNamespace="http://www.example.com" elementFormDefault="qualified"> <xs:complexType name="iDetails"> <xs:sequence> <xs:element name="name"/> </xs:sequence> </xs:complexType> </xs:schema> |
This demonstrates substitution. All three XML documents are valid against the schema. |
<?xml version="1.0" ?> <section xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="body.xsd"> <p>Hello World!</p> </section> |
<?xml version="1.0" ?> <body xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="body.xsd"> <div>Hello World!</div> </body> |
<?xml version="1.0" ?> <section xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="body.xsd"> <div>Hello World!</div> </section> |
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified"> <xs:complexType name="sContent"> <xs:sequence> <xs:element ref="p"/> </xs:sequence> </xs:complexType> <xs:element name="section" type="sContent"/> <xs:element name="body" substitutionGroup="section"/> <xs:element name="p" type="xs:string"/> <xs:element name="span" type="xs:string"/> <xs:element name="div" substitutionGroup="p span"/> </xs:schema> |
element and complexType can have the following attributes:
|
This example illustrates identity constraints. Each child of <items> must have a ‘number’ attribute whose value matches one of these unique product numbers. Each <product> element must have a <number> child whose value is unique. |
<?xml version="1.0" ?> <shipment xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="shipment.xsd"> <number>987QWERTY</number> <items> <thermometer number="876"> <quantity>1</quantity> <color value="blue"/> </thermometer> <thermometer number="876"> <quantity>1</quantity> <color value="sage"/> </thermometer> <pump number="432"> <quantity>1</quantity> </pump> </items> <products> <product> <number>876</number> <name>TM-902C K Type Digital Thermometer</name> <price currency="USD">14.99</price> </product> <product> <number>432</number> <name>3CFM 1/4HP Rotary Vane Vacuum Pump</name> <price currency="USD">59.99</price> </product> </products> </shipment> |
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified"> <xs:element name="shipment" type="OrderType"> <xs:keyref name="prodNumKeyRef" refer="prodNumKey"> <xs:selector xpath="items/*"/> <xs:field xpath="@number"/> </xs:keyref> <xs:key name="prodNumKey"> <xs:selector xpath=".//product"/> <xs:field xpath="number"/> </xs:key> </xs:element> <xs:complexType name="OrderType"> <xs:sequence> <xs:element name="number" type="xs:string"/> <xs:element name="items" type="ItemsType"/> <xs:element name="products" type="ProductsType"/> </xs:sequence> </xs:complexType> <xs:complexType name="ItemsType"> <xs:choice maxOccurs="unbounded"> <xs:element name="thermometer" type="ProductOrderType"/> <xs:element name="pump" type="ProductOrderType"/> </xs:choice> </xs:complexType> <xs:complexType name="ProductOrderType"> <xs:sequence> <xs:element name="quantity" type="xs:integer"/> <xs:element name="color" type="ColorType" minOccurs="0"/> </xs:sequence> <xs:attribute name="number" type="xs:integer"/> </xs:complexType> <xs:complexType name="ProductsType"> <xs:sequence> <xs:element name="product" type="ProductType" maxOccurs="unbounded"/> </xs:sequence> </xs:complexType> <xs:complexType name="ProductType"> <xs:sequence> <xs:element name="number" type="xs:integer"/> <xs:element name="name" type="xs:string"/> <xs:element name="price" type="PriceType"/> </xs:sequence> </xs:complexType> <xs:complexType name="ColorType"> <xs:attribute name="value" type="xs:string"/> </xs:complexType> <xs:complexType name="PriceType"> <xs:simpleContent> <xs:extension base="xs:decimal"> <xs:attribute name="currency" type="xs:token"/> </xs:extension> </xs:simpleContent> </xs:complexType> </xs:schema> |