Hinweis
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, sich anzumelden oder das Verzeichnis zu wechseln.
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, das Verzeichnis zu wechseln.
Vor SQL Server 2005 Service Pack 1 (SP1) lehnte SQL Server XML-Schemas ab, die nicht deterministische Inhaltsmodelle enthielten.
Ab SQL Server 2005 SP1 werden nicht deterministische Inhaltsmodelle jedoch akzeptiert, wenn die Vorkommenseinschränkungen 0,1 oder unbegrenzt lauten.
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, die älter als SQL Server 2005 SP1 sind, abgelehnt werden.
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
Siehe auch
Verweis
Anforderungen und Einschränkungen für XML-Schemaauflistungen auf dem Server