Share via


Nicht deterministische Inhaltsmodelle

Gilt für:SQL ServerAzure SQL-DatenbankAzure SQL Managed Instance

Nicht deterministische Inhaltsmodelle werden in SQL Server akzeptiert, wenn die Vorkommenseinschränkungen 0, 1 oder ungebunden sind.

Vor SQL Server 2005 (9.x) Service Pack 1 (SP1) lehnte SQL Server XML-Schemas ab, die nicht deterministische Inhaltsmodelle hatten.

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 es nicht klar ist, ob das <root> Element eine Sequenz von zwei <a> Elementen aufweisen soll oder ob das <root> Element zwei Sequenzen aufweisen soll, jeweils mit einem <a> Element.

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

Siehe auch