在创建具有 XML 类型列的表时,我指的是复杂的 XML 模式集合。当我指定 XML 模式时,我没有指定 DOCUMENT 或 CONTENT 选项,假设默认值为 CONTENT。
我能够插入具有顶级节点的 xml 数据,但无法插入其他 xml 片段。
请参阅下面提到的 xml 片段和架构
- 插入xml片段
INSERT INTO [testdb].[dbo].[dummy6]
([ItemData])
VALUES
('
<shipto xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="shipto.xsd">
<name>Ola Nordmann</name>
<address>Langgt 23</address>
<city>4000 Stavanger</city>
<country>Norway</country>
</shipto>');
- 架构
DROP XML SCHEMA COLLECTION shipOrderCollection
CREATE XML SCHEMA COLLECTION shipOrderCollection AS
'
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="shiporder">
<xs:complexType>
<xs:sequence>
<xs:element name="orderperson" type="xs:string"/>
<xs:element name="shipto">
<xs:complexType>
<xs:sequence>
<xs:element name="name" type="xs:string"/>
<xs:element name="address" type="xs:string"/>
<xs:element name="city" type="xs:string"/>
<xs:element name="country" type="xs:string"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="item" maxOccurs="unbounded">
<xs:complexType>
<xs:sequence>
<xs:element name="title" type="xs:string"/>
<xs:element name="note" type="xs:string" minOccurs="0"/>
<xs:element name="quantity" type="xs:positiveInteger"/>
<xs:element name="price" type="xs:decimal"/>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:sequence>
<xs:attribute name="orderid" type="xs:string" use="required"/>
</xs:complexType>
</xs:element>
' ; 去