Недетерминированные модели содержимого

Область применения: SQL Server (все поддерживаемые версии) База данных SQL Azure Управляемый экземпляр SQL Azure

Недетерминированные модели содержимого принимаются в SQL Server, если ограничения вхождения имеют значение 0, 1 или неограниченны.

В версиях, предшествующих SQL Server 2005 (9.x) с пакетом обновления 1 (SP1), схемы XML, содержащие недетерминированные модели содержимого, отклонялись SQL Server .

Пример Недетерминированные модели содержимого отклоняются

В следующем примере предпринимается попытка создать 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 (9.x) с пакетом обновления 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

См. также раздел