Nicht deterministische Inhaltsmodelle
Vor SQL Server 2005 Service Pack 1 (SP1) SQL Server XML-Schemas abgelehnt, die nicht deterministische Inhaltsmodelle enthielten.
Ab SQL Server 2005 SP1 werden jedoch nicht deterministische Inhaltsmodelle akzeptiert, wenn die Vorkommenseinschränkungen 0,1 oder ungebunden sind.
Beispiel: Nicht deterministisches Inhaltsmodell abgelehnt
Im folgenden Beispiel wird versucht, ein XML-Schema mit einem nicht deterministischen Inhaltsmodell zu erstellen. Der Code schlägt fehl, da unklar ist, ob das <root>
-Element eine Sequenz mit zwei <a>
-Elementen oder ob das <root>
-Element zwei Sequenzen mit jeweils einem <a>
-Element haben sollte.
CREATE XML SCHEMA COLLECTION MyCollection AS '
<schema xmlns="http://www.w3.org/2001/XMLSchema">
<element name="root">
<complexType>
<sequence minOccurs="1" maxOccurs="2">
<element name="a" type="string" minOccurs="1" maxOccurs="2"/>
</sequence>
</complexType>
</element>
</schema>
'
GO
Das Schema kann durch Verschieben der Vorkommenseinschränkung an einen eindeutigen Speicherort korrigiert werden. So kann z. B. die Einschränkung zum enthaltenden Sequenzpartikel verschoben werden:
<sequence minOccurs="1" maxOccurs="4">
<element name="a" type="string" minOccurs="1" maxOccurs="1"/>
</sequence>
Oder die Einschränkung kann zum enthaltenen Element verschoben werden:
<sequence minOccurs="1" maxOccurs="1">
<element name="a" type="string" minOccurs="1" maxOccurs="4"/>
</sequence>
Beispiel: Nicht deterministisches Inhaltsmodell akzeptiert
Das folgende Schema würde in Versionen von SQL Server vor SQL Server 2005 SP1 abgelehnt.
CREATE XML SCHEMA COLLECTION MyCollection AS '
<schema xmlns="http://www.w3.org/2001/XMLSchema">
<element name="root">
<complexType>
<sequence minOccurs="0" maxOccurs="unbounded">
<element name="a" type="string" minOccurs="0" maxOccurs="1"/>
<element name="b" type="string" minOccurs="1" maxOccurs="unbounded"/>
</sequence>
</complexType>
</element>
</schema>
'
GO
Weitere Informationen
Anforderungen und Einschränkungen für XML-Schemaauflistungen auf dem Server