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