Есть ли способ наложить ограничение на тип XML для типизированного столбца XML в SQL Server?

У меня есть две XML-схемы, где одна зависит от другой, и я хотел бы создать типизированный XML-столбец в SQL Server, где тип определяется одной из моих схем (на самом деле у меня есть сотни схем, но в принципе это одно и то же), Когда я создаю столбец, он принимает все типы, определенные во всей моей коллекции схем, и я действительно хотел бы ограничить тип для одного столбца только одним из типов.

<schema targetnamespace="b">
   <simpleType name="b">
       <restriction base="string"><pattern value="(0[1-9])"/></restriction>
   </simpleType>
</schema>

<schema targetnamespace="a" xmlns:b="b">
   <element name="b" type="b:b" />
   <complexType name="aType">
      <sequence>
         <element ref="b"/>
      </sequence>
   </complexType>
   <element name="a" type="aType"/>
</schema>

Итак, сначала я создаю коллекцию схем с

CREATE XML SCHEMA COLLECTION Foo AS N'<above schemas>'

а затем я создаю столбец с

ALTER TABLE FooTable ADD fooCol [xml] (Document [Foo])

Теперь я могу вставлять значения в столбец типов XML "a", а также "b", но я бы действительно хотел ограничить тип столбца только "a".

Есть ли способ достичь этого, если не считать рукописных настраиваемых коллекций схем для каждого типа?

Обновлено:

Что касается предложенного проверочного ограничения - согласно http://blogs.msdn.com/b/denisruc/archive/2006/08/22/713342.aspx тогда проверочное ограничение будет чем-то вроде

CREATE FUNCTION dbo.checkTopElmntIsTypeA(@x XML(MySchemaCollection))
RETURNS bit
AS
BEGIN
    RETURN ~(@x.exist('/a:a'))
END
go

и определение таблицы, чтобы ограничить содержимое столбца XML-типом

CREATE TABLE T(xmlCol XML(MySchemaCollection)
    CHECK (1 = dbo.checkTopElmntIsTypeA(xmlCol)))
go

Я думаю, что это может сделать, даже если это не так хорошо.:-)

0 ответов

Другие вопросы по тегам