Udostępnij za pośrednictwem


Firmy Deterministic Networks zawartości modeli

Przed SQL Server 2005 Service Pack 1 (SP1), SQL Server Odrzucone schematów XML, które miały - deterministic zawartości modeli.

Począwszy od SQL Server 2005 z dodatkiem SP1, jednak zawartość deterministic modele są akceptowane, jeśli ograniczenia występowania 0,1 lub o nieokreślonej długości.

Przykład: Deterministic inne niż model zawartości odrzucone

Poniższy przykład próbuje utworzyć schemat XML-deterministic modelu zawartości.Kod zakończy się niepowodzeniem, ponieważ nie jest jasne czy <root> element powinien mieć z sekwencji <a> elementów lub jeśli <root> element powinien mieć dwóch sekwencji, każdy z <a> elementu.

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ć poprzez przenoszenie ograniczenia występowania w unikatowej lokalizacji.Na przykład ograniczenia mogą być przenoszone do cząstka zawierających 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: Akceptowany model deterministyczny bez zawartości

Następującego schematu będzie odrzucony 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