我正在使用SQL Server2008,正忙着做一个POC,其中我有一个带有类型化XML列的表。POC的本质是,随着我们对存储在其中的数据的需求的发展,XML将随着时间的推移而变化。(我们在C#中序列化对象以将数据持久化到DB)
但是,出于审计的目的,我需要将旧的XML保留在表中,并且能够使用更新后的模式正确地验证添加到表中的任何新的XML。
我尝试从集合中删除模式,更新它(在本例中添加一个必需的属性),将其添加回集合,然后将其绑定到它所属的列。这样做时,我只会得到一个验证错误,即列中已有的XML没有通过验证,因为它不包含新属性。
有没有办法更新XML列以使用新的Schema并忽略已存储在该列中的XML?或者,是否可以在将新模式添加到XML列时禁用验证?
发布于 2013-06-19 02:22:39
架构集合应该允许您拥有不同版本的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表中已经存在的旧数据将根据旧模式进行验证,而任何新数据都将根据旧的或新模式进行验证。
如果您只想针对较新的模式进行验证,则必须向该列添加额外的约束。
https://stackoverflow.com/questions/17164884
复制相似问题