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>
'; 行く