Пример. Запросы к схемам как к результатам с помощью параметров XMLDATA и XMLSCHEMA

В следующем запросе возвращается схема XML-DATA, описывающая структуру документа.

Пример

USE AdventureWorks2008R2;
GO
SELECT ProductModelID, Name
FROM Production.ProductModel
WHERE ProductModelID=122 or ProductModelID=119
FOR XML RAW, XMLDATA ;
GO

Результат:

<Schema name="Schema1" xmlns="urn:schemas-microsoft-com:xml-data"

xmlns:dt="urn:schemas-microsoft-com:datatypes">

<ElementType name="row" content="empty" model="closed">

<AttributeType name="ProductModelID" dt:type="i4" />

<AttributeType name="Name" dt:type="string" />

<attribute type="ProductModelID" />

<attribute type="Name" />

</ElementType>

</Schema>

<row xmlns="x-schema:#Schema1" ProductModelID="122" Name="All-Purpose Bike Stand" />

<row xmlns="x-schema:#Schema1" ProductModelID="119" Name="Bike Wash" />

ПримечаниеПримечание

<Schema> задается в качестве пространства имен. Во избежание конфликтов пространств имен при запросе нескольких схем XML-Data различными запросами FOR XML идентификатор пространства имен (в этом примере это Schema1) изменяется при каждом выполнении запроса. Идентификатор пространства имен определяется как Scheman, где n является целым числом.

Задавая параметр XMLSCHEMA, можно произвести запрос XSD-схемы документа.

USE AdventureWorks2008R2;
GO
SELECT ProductModelID, Name
FROM Production.ProductModel
WHERE ProductModelID=122 or ProductModelID=119
FOR XML RAW, XMLSCHEMA ;
GO

Результат:

<xsd:schema targetNamespace="urn:schemas-microsoft-com:sql:SqlRowSet1" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:sqltypes="https://schemas.microsoft.com/sqlserver/2004/sqltypes" elementFormDefault="qualified">

<xsd:import namespace="https://schemas.microsoft.com/sqlserver/2004/sqltypes" schemaLocation="https://schemas.microsoft.com/sqlserver/2004/sqltypes/sqltypes.xsd" />

<xsd:element name="row">

<xsd:complexType>

<xsd:attribute name="ProductModelID" type="sqltypes:int" use="required" />

<xsd:attribute name="Name" use="required">

<xsd:simpleType sqltypes:sqlTypeAlias="[AdventureWorks2008R2].[dbo].[Name]">

<xsd:restriction base="sqltypes:nvarchar" sqltypes:localeId="1049" sqltypes:sqlCompareOptions="IgnoreCase IgnoreKanaType IgnoreWidth" sqltypes:sqlSortId="52">

<xsd:maxLength value="50" />

</xsd:restriction>

</xsd:simpleType>

</xsd:attribute>

</xsd:complexType>

</xsd:element>

</xsd:schema>

<row xmlns="urn:schemas-microsoft-com:sql:SqlRowSet1" ProductModelID="122" Name="All-Purpose Bike Stand" />

<row xmlns="urn:schemas-microsoft-com:sql:SqlRowSet1" ProductModelID="119" Name="Bike Wash" />

Можно определить URI-код целевого пространства имен в качестве дополнительного аргумента XMLSCHEMA в FOR XML. Это задаст определенное целевое пространство имен в схеме. Это целевое пространство имен остается одинаковым при каждом последующем выполнении запроса. Например, в следующую измененную версию предыдущего запроса включен в качестве аргумента URI-код пространства имен 'urn:example.com'.

USE AdventureWorks2008R2;
GO
SELECT ProductModelID, Name
FROM Production.ProductModel
WHERE ProductModelID=122 or ProductModelID=119
FOR XML RAW, XMLSCHEMA ('urn:example.com') ;
GO

Результат:

<xsd:schema targetNamespace="urn:example.com" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:sqltypes="https://schemas.microsoft.com/sqlserver/2004/sqltypes" elementFormDefault="qualified">

<xsd:import namespace="https://schemas.microsoft.com/sqlserver/2004/sqltypes" schemaLocation="https://schemas.microsoft.com/sqlserver/2004/sqltypes/sqltypes.xsd" />

<xsd:element name="row">

<xsd:complexType>

<xsd:attribute name="ProductModelID" type="sqltypes:int" use="required" />

<xsd:attribute name="Name" use="required">

<xsd:simpleType sqltypes:sqlTypeAlias="[AdventureWorks2008R2].[dbo].[Name]">

<xsd:restriction base="sqltypes:nvarchar" sqltypes:localeId="1049" sqltypes:sqlCompareOptions="IgnoreCase IgnoreKanaType IgnoreWidth" sqltypes:sqlSortId="52">

<xsd:maxLength value="50" />

</xsd:restriction>

</xsd:simpleType>

</xsd:attribute>

</xsd:complexType>

</xsd:element>

</xsd:schema>

<row xmlns="urn:example.com" ProductModelID="122" Name="All-Purpose Bike Stand" />

<row xmlns="urn:example.com" ProductModelID="119" Name="Bike Wash" />

См. также

Справочник