Udostępnij za pośrednictwem


Przykład: Schematy wnioskujące jako wyniki za pomocą opcji schematu XML i XMLDATA

Następująca kwerenda zwraca schematu danych XML, który opisuje strukturę dokumentu.

Przykład

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

Jest to wynikiem:

<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" />

Ostrzeżenie

<Schema> Jest zadeklarowana jako obszaru nazw.W celu uniknięcia kolizji nazw, gdy wiele schematów XML dane są wymagane w różnych XML dla kwerendy, identyfikator obszaru nazw Schema1 w tym przykładzie zmian co wykonanie kwerendy.Identyfikator obszaru nazw składa się z schematun gdzie n jest liczbą całkowitą.

Określając XMLSCHEMA opcji, można zażądać schematu XSD wynik.

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

Jest to wynikiem:

<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="1033" 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" />

Można określić miejsce docelowe identyfikatora URI jako opcjonalny argument schematu XML w formacie XML dla obszaru nazw.To zwraca określony miejsce docelowe obszar nazw schematu.To docelowego obszaru nazw nie zmienia się co czas wykonanie kwerendy.Na przykład zmodyfikowaną wersja poprzedniej kwerendy zawiera identyfikator URI obszaru nazw 'urn:example.com', jako argument.

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

Jest to wynikiem:

<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="1033" 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" />

Zobacz także

Odwołanie