开发者社区


Web服务 | ASP/ASP.Net | JSP | PHP/Perl | 网站设计
首页 - WEB技术
Web技术
全文搜索:   

在关系数据库中保存大量XML文档
作者: ZDNent China
2003-11-10 12:07:09



本文译自Builder.com,未经许可请勿转载

当在关系数据库中保存XML文档的时候,由于采用方法上的原因,尤其是对于大量的文档,你一定碰到过很多问题。这一篇文章将提出与大量XML文档相关的特定的问题,然后给出解决这些问题的方法。

 

数量非常大的文档的潜在问题

什么东西使得一个XML文档变得非常巨大?一个XML文档变得巨大的其中一个迹象是文档启动的时候就出现问题。现在让我们讨论其中的潜在问题。

首先是有关原始空间(raw space)的观点。出现的问题与频率和空间相关。并不是你的文档大于通常情况下的状态,而是你频繁地使用它们。你必须需要有一个良好的尺寸数据分区来存放这些文档(或者数据库)。

第二,运行数据库可能会产生错误。有时候XML文档会分成多个部分,并存放在代表XML文档结构的不连续的表中,但通常情况下,XML文档存放在BLOB域,文本域,或者VARCHAR域中。

除在设计上的缺欠之外,你还有可能碰到与数据库相互通讯的界面上的问题。例如,绝大多数SQL执行都限制数据为4,096字节——这就意味着,当使用SQL必向数据库发送10KB文档的时候,你会遭到障碍。在数据库存储程序中也会存在类似的限制。如果你没有意识到这些限制以及你的文档超出范围,你将会碰到这些问题。

 

数据库设计

开发人员和数据库管理人员必须清楚地理解XML文档中将要产生的操作,这样才有可能正确地设计数据库。理解数据库将如何被使用也同样是相当的重要。你的XML文档是简单的连续存放机制?还是存放在非连续的状态之中?

如果你以整块方式存储整个文档,这样你就有多种选择。对于非连续数据,你应该设计出代表XML结构的表,并将数据分开存放在独立的表中。第二个步骤的优点是在于可索引性和可查询性,而你不需要对整个文档进行操作。

BLOB(二进制大型对象)域被用于存储大型的二进制格式的数据。例如,加密文件常用于BLOB域。BLOB域非常适合于存放XML文件。BLOB域的缺点是它不是可索引性和可查询性,以及不能通过标准的SQL与BLOB交换大量的数据。

 

【下一页】
声明:
Builder.com.cn(原ZDNet China应用开发频道)原创文章版权所有,未经许可严禁转载,且不构成投资建议。
近期相关报道:
实用技术文档
J2me XML
C/C++ C#
Java Oracle
Mysql .Net
VB.NET CSS
SQL Server 数据库
SQL UNIX
Linux Jsp
PHP Perl
Javascript IIS
XHTML ColdFusion
ASP/ASP.NET Apache
AJAX
订阅技术邮件
订阅"技术圈"杂志!请在下面选择您感兴趣的专题,填写e-mail地址,然后按订阅按钮:
应用开发管理
VS.NET 周刊
Database 周刊
WEB Service周刊
JAVA 周刊
IT 认证
Windows服务器周刊
互联网开发
当Windows Server 2008专家得5000元现金大奖
CNET NETWORKS 中国: 爱卡汽车网 | CNET科技资讯网 | e询网 | CWEEK | 蜂鸟网 | GameSpot China | 个人电脑 | PChome | SPN | 网友世界 | ZDNet China | 中关村在线
CNET NETWORKS 美国: BNET | CNET.com | CNET Download.com | CNET News.com | CNET Reviews | CNET Shopper.com | GameSpot | MP3.com | mySimon | Release 1.0 | Search.com | TechRepublic | TV.com | Webshots | ZDNet
Copyright (c) 2006 CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
ZDNet 公司标识是 CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号