用DataSet.ReadXml读取无Scheme的XML提速方法

翻译|其它|编辑:郝浩|2008-03-06 10:42:56.000|阅读 862 次

概述:

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

      单纯用DataSet的ReadXml方法读取XML对于小数据量来说效率很高,但是对大数据量的XML来说就有些力不从心了。比如,让DataSet读取一个16M的XML,能让你等到地老天荒。如果你的机器配置不高,那肯定死的很难看、很窝囊。

  题外话:如果XML来自DataSet,那么你是幸运的。你可以DataSet把架构信息带上,别因膨胀那么几k的数据就舍不得了。

  ReadXML缺省使用XmlReadMode.Auto方式读取,这就给大数据量留下了低效率的伏笔。因为如果XML没有Scheme,DataSet就会自己推算XML的结构,然后再加载,这就是低效的主要原因。让DataSet推算不让我们帮他算,因为DataSet已经提供了一个ReadXmlSchema方法。
如下:

  Dim XMLText As String '保存了XML的文本
  Dim MyDs As New DataSet
  Dim MyTab As DataTable

  '加载架构
  MyDs.ReadXmlSchema(New IO.StringReader(XMLText))
  For Each MyTab In MyDs.Tables
  MyTab.BeginLoadData()
  Next

  然后再让DataSet加载数据。
  注意:因为前面我们一个帮他加载架构信息了,这里就可以让DataSet加载数据时忽略Schema。
  '加载数据
  MyDs.ReadXml(New IO.StringReader(XMLText), XmlReadMode.IgnoreSchema)
  For Each MyTab In MyDs.Tables
  MyTab.EndLoadData()
  Next

  Ok,这样就把数据快速的加载到DataSet了。经过实际测试,数据量越大效率比就越高。

  通常获得DataSet的XML的方法是用GetXml,确实方便。但是返回的结果已经把DataSet的架构信息抹掉了,剩下的是单纯的数据。DataSet还给我们留了一个WriteXml方法(感动ing,勿扰....),这个方法可以把DataSet的数据写到文件或流中。
比如:
  Dim MS As New IO.MemoryStream
  DataSet.WriteXml(MS, XmlWriteMode.WriteSchema) '后面参数是关键,指明要带上架构信息。

  这样在MS这个流中就保存了带DataSet架构信息的全部数据。
标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:csdn

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP