SQL SQL 服务器 2008 允许我们根据现有的 XML Schema 收藏来验证 XML, 定义了打印的 XML 列/ 可变的 : < code>DECLARE @ TypedXml XML (MyXmlSchema Collection) code>
然而,据我所知,在我们定义列/可变列时,必须知道XML Schema收藏。
是否有方法使用 runtime em> 指定的 XML 模式验证 XML?
例如:
DECLARE @Xml XML
SET @Xml =
N <person>
<firstname>Ming</firstname>
<lastname>The Merciless</lastname>
</person>
DECLARE @Xsd XML
SET @Xsd =
N <?xml version="1.0"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="person">
<xs:complexType>
<xs:sequence>
<xs:element name="firstname" type="xs:string"/>
<xs:element name="lastname" type="xs:string"/>
<xs:element name="dateofbirth" type="xs:date"/>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
DECLARE @Valid BIT
SET @Valid = (SELECT dbo.f_ValidateXmlAgainstXsd(@Xml, @Xsd)) -- With a user-defined function?
EXEC @Valid = s_ValidateXmlAgainstXsd @Xml, @Xsd -- With a stored procedure?