草庐IT

.net - 确定是将 XML 数据存储为 XML 还是规范化表

coder 2024-06-24 原文

(这篇文章征求了有关存储 XML 的个人经验;请分享您所知道的。:-))

我正在开发一个使用 XML 与外部服务通信的服务应用程序。我计划使用 SQL Server 2008 来存储接收和发送到外部服务的 XML。我正在探索将 XML 存储在数据库中的选项。我确定的三个选项是:

  1. 将 XML 存储在 XML 数据类型列中
  2. 创建表格来存储 XML 中表示的各种父子关系。
  3. 上述两种方法的混合,其中原始 XML 存储在 XML 数据类型列中,但 XML 中的多个字段分解为它们自己的列以简化查询和索引。

我正在根据您的个人经验寻找有关在 SQL Server 中存储和检索 XML 数据的任何建议。

一些额外的背景:我使用了 'xsd.exe'相当于 XsdObjectgenerator基于 XML 模式创建 .net 类。当服务收到 XML 文件时,它被反序列化为 .net 类的一个实例。该实例用于执行服务的操作。我最初的计划是然后使用上面的选项 #1 来存储 XML。如果我需要更新或报告数据,我只需将数据库记录反序列化回我的 .net 类之一。

虽然这种方法行得通并且使使用 xml 变得非常简单,但我担心随着数据量的增加,查询 XML 数据类型记录的性能会下降。这就是我探索上面选项 2 和 3 的原因。

除了存储 XML 之外,还将查询 XML 以便在报告和单独的 Web 应用程序中使用。最终用户将查询、排序、过滤、分组、汇总并可能更新数据库记录。

最佳答案

我想这取决于您想对数据库中的 XML 做什么。

如果您主要只是存储它,并且可能稍后将其作为一个整体检索并再次发送,那么我肯定会使用 XML 数据类型 - 没有必要将它分解成零碎的。

但是,如果您主要需要处理 XML 文件的内容,并且可能还需要操作和更改该内容,那么建议创建包含与您的 XML 内容相匹配的列的表,并在存储时将其切碎,使用它,并在需要时使用类似 SELECT (columns) FROM dbo.Table FOR XML.....

之类的东西从关系部分重新组合它

分解和重新组装会产生开销 - 因此您需要问问自己这样做是否值得。但是,如果您需要过多地操作 XML 列,也会产生开销。

如果您只需要对 XML 中的几个属性进行只读访问,我开始欣赏将这些属性包装到 UDF 中并将其显示为表中的计算列的能力。这样,您可以根据存储在 XML 中某处的值轻松地从表中选择内容 - 非常方便!但是不要过度使用这种方法——适用于 2、3 个属性——但是如果你需要一遍又一遍地访问你的 XML(以及大部分或全部),那么你最好将它分解成关系部分来开始.

关于.net - 确定是将 XML 数据存储为 XML 还是规范化表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3180538/

有关.net - 确定是将 XML 数据存储为 XML 还是规范化表的更多相关文章

  1. ruby-on-rails - Ruby net/ldap 模块中的内存泄漏 - 2

    作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代

  2. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  3. ruby-on-rails - 如何从 format.xml 中删除 <hash></hash> - 2

    我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为

  4. ruby - 如何模拟 Net::HTTP::Post? - 2

    是的,我知道最好使用webmock,但我想知道如何在RSpec中模拟此方法:defmethod_to_testurl=URI.parseurireq=Net::HTTP::Post.newurl.pathres=Net::HTTP.start(url.host,url.port)do|http|http.requestreq,foo:1endresend这是RSpec:let(:uri){'http://example.com'}specify'HTTPcall'dohttp=mock:httpNet::HTTP.stub!(:start).and_yieldhttphttp.shou

  5. ruby - 即时确定方法的可见性 - 2

    我正在编写一个方法,它将在一个类中定义一个实例方法;类似于attr_accessor:classFoocustom_method(:foo)end我通过将custom_method函数添加到Module模块并使用define_method定义方法来实现它,效果很好。但我无法弄清楚如何考虑类(class)的可见性属性。例如,在下面的类中classFoocustom_method(:foo)privatecustom_method(:bar)end第一个生成的方法(foo)必须是公共(public)的,第二个(bar)必须是私有(private)的。我怎么做?或者,如何找到调用我的cust

  6. ruby - Ruby 有 `Pair` 数据类型吗? - 2

    有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳

  7. ruby - 寻找通过阅读代码确定编程语言的ruby gem? - 2

    几个月前,我读了一篇关于ruby​​gem的博客文章,它可以通过阅读代码本身来确定编程语言。对于我的生活,我不记得博客或gem的名称。谷歌搜索“ruby编程语言猜测”及其变体也无济于事。有人碰巧知道相关gem的名称吗? 最佳答案 是这个吗:http://github.com/chrislo/sourceclassifier/tree/master 关于ruby-寻找通过阅读代码确定编程语言的rubygem?,我们在StackOverflow上找到一个类似的问题:

  8. ruby - Net::HTTP 获取源代码和状态 - 2

    我目前正在使用以下方法获取页面的源代码:Net::HTTP.get(URI.parse(page.url))我还想获取HTTP状态,而无需发出第二个请求。有没有办法用另一种方法做到这一点?我一直在查看文档,但似乎找不到我要找的东西。 最佳答案 在我看来,除非您需要一些真正的低级访问或控制,否则最好使用Ruby的内置Open::URI模块:require'open-uri'io=open('http://www.example.org/')#=>#body=io.read[0,50]#=>"["200","OK"]io.base_ur

  9. ruby - 我如何添加二进制数据来遏制 POST - 2

    我正在尝试使用Curbgem执行以下POST以解析云curl-XPOST\-H"X-Parse-Application-Id:PARSE_APP_ID"\-H"X-Parse-REST-API-Key:PARSE_API_KEY"\-H"Content-Type:image/jpeg"\--data-binary'@myPicture.jpg'\https://api.parse.com/1/files/pic.jpg用这个:curl=Curl::Easy.new("https://api.parse.com/1/files/lion.jpg")curl.multipart_form_

  10. 世界前沿3D开发引擎HOOPS全面讲解——集3D数据读取、3D图形渲染、3D数据发布于一体的全新3D应用开发工具 - 2

    无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD

随机推荐