2

我正在使用 SQL Server 2008 并忙于做 POC,其中我有一个带有类型 XML 列的表。POC 的本质是随着我们对存储在其中的数据的需求的发展,XML 会随着时间而改变。(我们在 C# 中序列化对象以将数据持久保存到数据库中)

但是,出于审计目的,我需要将旧 XML 保留在表中,并且能够使用更新的模式验证正确添加到其中的任何新 XML。

我尝试从集合中删除模式,更新它(在这种情况下添加必需的属性),将其添加回集合,然后将其绑定到它所属的列。这样做时,我只是得到一个验证错误,即列中的 XML 验证失败,因为它不包含新属性。

有没有办法更新 XML 列以使用新架构并忽略已存储在列中的 XML?或者是否可以在将新模式添加到 XML 列时禁用验证?

4

1 回答 1

4

模式集合应该允许您拥有不同版本的 XML 数据,而不必忽略验证。

首先看一下XML Schema Collections

在您的 T-SQL 代码中,您将拥有类似这样的内容(此代码来自SQLskills.com的Bob Beauchemin ):

-- Load XML schema from file
DECLARE @x XML
SET @x = (
SELECT * FROM OPENROWSET(
   BULK 'C:\invoice.xsd',
           SINGLE_BLOB
   ) AS x
)

-- And use it to create an XML schema collection
CREATE XML SCHEMA COLLECTION InvoiceType AS @x

现在创建一个将列映射到模式集合的表:

CREATE TABLE invoice_docs (
   invoiceid INTEGER PRIMARY KEY IDENTITY,
   invoice   XML(document InvoiceType)
)

现在,当您的架构更改时,您可以通过添加新版本的架构来修改架构集合:

DECLARE @x XML
SET @x = (
SELECT * FROM OPENROWSET(
   BULK 'C:\invoice_v2.xsd',
           SINGLE_BLOB
   ) AS x
)

-- And use it to create an XML schema collection
-- Allow V1 and V2 invoices
ALTER XML SCHEMA COLLECTION InvoiceType ADD @x

表中已有的旧数据将根据旧模式进行验证,任何新数据都将根据旧模式新模式进行验证。

如果您只想针对较新的架构进行验证,则必须向该列添加额外的约束。

于 2013-06-18T18:22:38.673 回答