Model konten non-Deterministik
Berlaku untuk:SQL ServerAzure SQL DatabaseAzure SQL Managed Instance
Model konten non-deterministik 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 model konten non-deterministik.
Contoh: Model konten non-deterministik ditolak
Contoh berikut mencoba membuat skema XML dengan model konten non-deterministik. 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: Model konten non-deterministik 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
Baca juga
Saran dan Komentar
https://aka.ms/ContentUserFeedback.
Segera hadir: Sepanjang tahun 2024 kami akan menghentikan penggunaan GitHub Issues sebagai mekanisme umpan balik untuk konten dan menggantinya dengan sistem umpan balik baru. Untuk mengetahui informasi selengkapnya, lihat:Kirim dan lihat umpan balik untuk