5

SQL Server 2008 允许我们通过定义一个类型化的 XML 列/变量来针对现有的 XML 模式集合验证 XML:DECLARE @TypedXml XML(MyXmlSchemaCollection)

但是,据我所知,在我们定义列/变量时必须知道 XML 模式集合。

有没有办法使用在运行时指定的 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?
4

2 回答 2

2

对于您的要求,我可能会探索 CLR 集成:使用存储过程用户定义的函数;您应该首先检查您的环境中是否允许 CLR 集成。

在这里张贴太多了;但是,使用 .NET 验证 XML 文档的代码很常见;只要 SQL 2008 出现,我添加到 SQL Server 在线书籍中的链接就会出现......

一般来说,我认为要实现不受 SQL Server 支持 XSD 方式限制的验证,应该依赖 CLR 集成。此处描述的 SQL 服务器上的 XSD 集合的限制无论如何都会使许多人朝这个方向发展。在大容量环境中需要解决一些问题,我认为缓存已编译的 XSD 是最重要的问题。另一个是 XSD 的复杂性,以及 XSD 的来源和引用方式(包括/导入/重新定义支持)。尝试自己实现这些方面肯定会让您了解 SQL Server 不支持 xsd:include 的原因......

于 2012-05-22T02:22:43.290 回答
0

如果要针对存储在数据库中的一组预定义 XSD 进行验证,则可以在存储过程中使用动态 SQL 来进行验证。

如果您想针对任何 XSD 进行验证,最好在 Petru 的回答中使用 CLR。

以下脚本将起作用。如果输入 XML 无效,它会引发异常。如果您希望验证仅返回结果而不是引发异常,则可以使用 try/catch 子句。

编辑:您不能在函数中使用动态 SQL,但可以将此脚本包装在存储过程中。

    DECLARE @result int

    DECLARE @XsdValidationSQL nvarchar(max) = 
        'DECLARE @xml xml(' + @xsdSchema + '.' + @xsdName + ') = ''' + CONVERT(nvarchar(max), @xml) + ''''

    EXEC @result = sp_executesql @XsdValidationSQL

    RETURN @result
于 2015-12-02T21:16:18.060 回答