Недетерминированные модели содержимого
В версиях, предшествующих SQL Server 2005 с пакетом обновления 1 (SP1), XML-схемы, содержащие недетерминированные модели содержимого, отклонялись SQL Server.
Начиная с версии SQL Server 2005 с пакетом обновления 1 (SP1), недетерминированные модели содержимого принимаются, если ограничение вхождений равно 0, 1 или без ограничений.
Пример. Недетерминированные модели содержимого отклоняются
В следующем примере предпринимается попытка создать XML-схему с недетерминированной моделью содержимого. Выполнение этого кода приведет к ошибке, поскольку неясно, должен ли элемент <root> содержать последовательность из двух элементов <a> или же элемент <root> должен содержать две последовательности, состоящие из элемента <a>.
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
Эту схему можно исправить перемещением ограничения вхождения в однозначное расположение. Например, ограничение можно переместить в содержащий последовательность примитив:
<sequence minOccurs="1" maxOccurs="4">
<element name="a" type="string" minOccurs="1" maxOccurs="1"/>
</sequence>
Ограничение можно также переместить во вложенный элемент:
<sequence minOccurs="1" maxOccurs="1">
<element name="a" type="string" minOccurs="1" maxOccurs="4"/>
</sequence>
Пример. Недетерминированные модели содержимого принимаются
Следующая схема отклоняется в версиях SQL Server, предшествующих SQL Server 2005 с пакетом обновления 1 (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