-Deterministyczny modele zawartości

Przed SQL Server 2005 Dodatek usługa Pack 1 (SP1) SQL Server odrzucone schematów XML, który miał-deterministyczny zawartości modeli.

Zaczyna się od SQL Server 2005 Z dodatkiem SP1, jednak nie deterministyczny zawartości modeli są akceptowane w przypadku ograniczenia wystąpienie 0,1 lub niepowiązany.

Przykład: Odrzucone deterministyczny innego niż model zawartości

W poniższym przykładzie próbuje utworzyć schematu XML z innych niż deterministyczny modelu zawartości.Kod nie powiedzie się, ponieważ nie jest oczywiste, czy <root> element powinien mieć sekwencję dwóch <a> elementy lub, jeśli <root> element powinna mieć dwie sekwencje, każdy z <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

Schemat można ustalić przenosząc ograniczenie wystąpienie unikatową lokalizację.Na przykład ograniczenia mogą być przenoszone do zawierające cząstka sekwencji:

<sequence minOccurs="1" maxOccurs="4">
    <element name="a" type="string" minOccurs="1" maxOccurs="1"/>
</sequence>

Lub ograniczenia mogą być przenoszone do zamkniętego elementu:

<sequence minOccurs="1" maxOccurs="1">
     <element name="a" type="string" minOccurs="1" maxOccurs="4"/>
</sequence>

Przykład: Zaakceptowane deterministyczny innego niż model zawartości

Następujący schemat może zostać odrzucone w wersjach SQL Server przed SQL Server 2005 Z DODATKIEM SP1.

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