您的位置:知识库 » .NET技术

WCF分布式开发步步为赢(8):使用数据集、数据表、集合传递数据

作者: Frank Xu Lei  来源: 博客园  发布时间: 2009-06-01 11:18  阅读: 6509 次  推荐: 0   原文链接   [收藏]  
摘要:数据集(DataSet)、数据表(DataTable)、集合(Collection)概念是.NET FrameWork里提供数据类型,在应用程序编程过程中会经常使用其来作为数据的载体,属于ADO.NET的一部分。
[1] 数据集(DataSet)、数据表(DataTable)
[2] 集合(Collection)
[3] 示例代码分析

  数据集(DataSet)、数据表(DataTable)、集合(Collection)概念是.NET FrameWork里提供数据类型,在应用程序编程过程中会经常使用其来作为数据的载体,属于ADO.NET的一部分。今天我们WCF分布式开发步步为赢第8节的内容:使用数据集(DataSet)、数据表(DataTable)、集合(Collection)传递数据。本节内容除了介绍几个类型概念外的,同样会详细给出代码的实现过程。此外我们会分析这几种数据类型的优势和缺点,以及在面向对象的服务开发过程中如何解决这些问题。

  【1】数据集(DataSet)、数据表(DataTable):

  我们首先来介绍这两个类型的相关概念,然后在介绍其在WCF应用程序开发中的使用方式。

  【1.1】基本概念:

  数据集(DataSet)、数据表(DataTable),相信大家都不回陌生,只要做过ADO.NET进行数据库编程的开发人员来说,都会使用到这两个类。DataSet 是 ADO.NET 结构的主要组件,它是从数据源中检索到的数据在内存中的缓存。DataSet 由一组 DataTable 对象组成,您可使这些对象与 DataRelation 对象互相关联。您还可通过使用 UniqueConstraint 和 ForeignKeyConstraint 对象在 DataSet 中实施数据完整性。有关使用 DataSet 对象的详细信息,请参见 在 ADO.NET 中使用 DataSet。

  尽管 DataTable 对象中包含数据,但是 DataRelationCollection 允许您遍览表的层次结构。这些表包含在通过 Tables 属性访问的 DataTableCollection 中。当访问 DataTable 对象时,请注意它们是按条件区分大小写的。例如,如果一个 DataTable 被命名为“mydatatable”,另一个被命名为“Mydatatable”,则用于搜索其中一个表的字符串被认为是区分大小写的。但是,如果“mydatatable”存在而“Mydatatable”不存在,则认为该搜索字符串不区分大小写。有关使用 DataTable 对象的更多信息,请参见 创建 DataTable。

  DataSet 可将数据和架构作为 XML 文档进行读写。数据和架构可通过 HTTP 传输,并在支持 XML 的任何平台上被任何应用程序使用。可使用 WriteXmlSchema 方法将架构保存为 XML 架构,并且可以使用 WriteXml 方法保存架构和数据。若要读取既包含架构也包含数据的 XML 文档,请使用 ReadXml 方法。

  在典型的多层实现中,用于创建和刷新 DataSet 并依次更新原始数据的步骤包括:

  1. 通过 DataAdapter 使用数据源中的数据生成和填充 DataSet 中的每个 DataTable。
  2. 通过添加、更新或删除 DataRow 对象更改单个 DataTable 对象中的数据。
  3. 调用 GetChanges 方法以创建只反映对数据进行的更改的第二个 DataSet。
  4. 调用 DataAdapter 的 Update 方法,并将第二个 DataSet 作为参数传递。
  5. 调用 Merge 方法将第二个 DataSet 中的更改合并到第一个中。
  6. 针对 DataSet 调用 AcceptChanges。或者,调用 RejectChanges 以取消更改。

  【1.2】
  DataSet 和 DataTable 对象从 MarshalByValueComponent 继承而来,并支持用于远程处理的 ISerializable 接口。这些是仅有的可以远程处理的 ADO.NET 对象。   我们先来看一下DataSet的定义,使用Reflector工具查看,部分代码如下:

[Serializable, ToolboxItem("Microsoft.VSDesigner.Data.VS.DataSetToolboxItem,
Microsoft.VSDesigner, Version=8.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7
f11d50a3a
"), DefaultProperty("DataSetName"), XmlSchemaProvider("GetDataSetSc
hema
"), ResDescription("DataSetDescr"), XmlRoot("DataSet"), Designer("Microsoft.
VSDesigner.Data.VS.DataSetDesigner, Microsoft.VSDesigner, Version=8.0.0.0,
Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a
")]
public class DataSet : MarshalByValueComponent, IListSource, IXmlSerializable,
 ISupportInitializeNotification, ISupportInitialize, ISerializable
{
    
// Fields
    private bool _caseSensitive;
    
private CultureInfo _culture;
    
private bool _cultureUserSet;
    
private string _datasetPrefix;
    
private object _defaultViewManagerLock;
    
private readonly int _objectID;
    
private static int _objectTypeCount;
    
private SerializationFormat _remotingFormat;
    
private string dataSetName;
    
private DataViewManager defaultViewManager;
    
private bool enforceConstraints;
    
internal PropertyCollection extendedProperties;
    
private bool fBoundToDocument;
    
internal bool fEnableCascading;
    
internal bool fInitInProgress;

 
}

 DataTable的部分实现代码如下:

[Serializable, Editor("Microsoft.VSDesigner.Data.Design.DataTableEditor, Microsoft.
VSDesigner, Version=8.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a
",
 
"System.Drawing.Design.UITypeEditor, System.Drawing, Version=2.0.0.0, Culture=
neutral, PublicKeyToken=b03f5f7f11d50a3a
"), DefaultProperty("TableName"),
DesignTimeVisible(
false), ToolboxItem(false), XmlSchemaProvider("GetDataTableS
chema
"), DefaultEvent("RowChanging")]
public class DataTable : MarshalByValueComponent, IListSource, ISupportInitialize
Notification, ISupportInitialize, ISerializable, IXmlSerializable
{
    
// Fields
    private bool _caseSensitive;
    
private bool _caseSensitiveUserSet;
    
internal DataColumn _colUnique;
    
private CompareOptions _compareFlags;
    
private CompareInfo _compareInfo;
    
}

  在WCF分布式应用程序开发过程中,可以使用来作为数据契约类型,在服务和客户端传递。两者在定义之初都包含了[Serializable]声明,因此两者的对象都是可以序列化的。可以使用在客户端和服务端传递数据。

0
0
标签:WCF

.NET技术热门文章

    .NET技术最新文章

      最新新闻

        热门新闻