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.
Gilt für: SQL Server
Azure SQL-Datenbank
Azure SQL Managed Instance
Nicht deterministische Inhaltsmodelle werden in SQL Server akzeptiert, wenn die Vorkommenseinschränkungen 0, 1 oder „unbegrenzt“ lauten.
Vor SQL Server 2005 (9.x) Service Pack 1 (SP1) lehnte SQL Server XML-Schemas ab, die nicht deterministische Inhaltsmodelle enthielten.
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 (9.x) 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