Bagikan melalui


Model konten non-Deterministik

Berlaku untuk: SQL ServerAzure SQL Database Azure SQL Managed Instance

Kontan non-deterministik mode tenda ls diterima di SQL Server jika batasan kemunculannya adalah 0, 1, atau tidak terbatas.

Sebelum SQL Server 2005 (9.x) Service Pack 1 (SP1), SQL Server menolak skema XML yang memiliki con non-deterministik mode tenda ls.

Contoh: Kontan non-deterministik mode tenda l ditolak

Contoh berikut mencoba membuat skema XML dengan kontan non-deterministik mode tenda l. Kode gagal karena tidak jelas apakah <root> elemen harus memiliki urutan dua <a> elemen atau jika <root> elemen harus memiliki dua urutan, masing-masing dengan <a> elemen.

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

Skema dapat diperbaiki dengan memindahkan batasan kemunculan ke lokasi yang unik. Misalnya, batasan dapat dipindahkan ke partikel urutan yang berisi:

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

Atau batasan dapat dipindahkan ke elemen yang terkandung:

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

Contoh: Kontan non-deterministik mode tenda l diterima

Skema berikut akan ditolak dalam versi SQL Server sebelum SQL Server 2005 (9.x) 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

Lihat juga