首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用新架构更新XML列架构

使用新架构更新XML列架构
EN

Stack Overflow用户
提问于 2013-06-18 17:09:19
回答 1查看 2.7K关注 0票数 2

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

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

我尝试从集合中删除模式,更新它(在本例中添加一个必需的属性),将其添加回集合,然后将其绑定到它所属的列。这样做时,我只会得到一个验证错误,即列中已有的XML没有通过验证,因为它不包含新属性。

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-06-19 02:22:39

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

让我们先看看XML Schema Collections

在您的T-SQL代码中,您应该有这样的代码(此代码来源于SQLskills.com的Bob Beauchemin ):

代码语言:javascript
复制
-- 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

现在,您将创建一个将列映射到架构集合的表:

代码语言:javascript
复制
CREATE TABLE invoice_docs (
   invoiceid INTEGER PRIMARY KEY IDENTITY,
   invoice   XML(document InvoiceType)
)

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

代码语言:javascript
复制
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

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

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

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17164884

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档