在Microsoft Office System中使用ADO.NET数据集(二)

类别:.NET开发 点击:0 评论:0 推荐:

创建一个DataSet

假定你必须使用一个灵活的数据对象这个对象允许你包含多个表在表与表之间设定关系以及向前或向后读取数据。

ADO.NET中提供这些特性——甚至更多——的对象就是DataSetDataSet是一种断开式(disconnected)对象,这意味着一旦填充完数据就不必保持数据库连接。到数据库服务器的网络连接即使断开了也不会影响你的客户端应用程序使用数据库中的数据。这项技术的优势之一就是你释放数据库连接给其他用户,并且你的应用程序不再依赖于这个连接。然而,这也意味着数据库中的数据在你填充完DataSet可能改变,你应该意识到这个可能的差异。

数据访问层可以创建多个DataSet对象。例如你可能使用一个DataSet容纳静态数据以便填充用户界面上的一个列表框或者你可能想使这些数据供多个用户访问。另一个对象可能包含某个用户更新后的数据,将更改回传到数据库中的代码尽可能简单也是必要的。现在,你可以使用一个对象完成这所有的需求。

1展示了Northwind数据库中各个表的结构这些表包含了客户和订单信息。你可以创建一个DataSet,作为这个数据库的结构镜像,或者完全改变它以适应你的应用程序需求。

1Northwind Customers DataSet 中使用的各个表的结构

下面的代码在GetDataSet方法中定义了一个DataSet包含了用户订单数据的全部列。它带有一个bSaveSchema参数,用于指示该过程是否需要将DataSet对象的XMLXML架构的拷贝保存为磁盘文件,这些文件将在该应用程序的其他部分使用。

GetDataSet的代码以实例化一个新的空DataSet对象开始这个DataSet对象被命名为NorthwindCustomerOrders如果你不提供给这个DataSet一个名称,这个DataSet将采用默认的命名NewDataSet这在大多数情况下没有什么问题,但是当你从这个DataSet生成并使用XML时,这个名字有时将作为XML结构的一部分。

Public Shared Function GetDataSet(ByVal bSaveSchema As Boolean) As DataSet

  'Instantiate the DataSet, giving it a custom name

  '(The default name is NewDataSet)

  Dim ds As New DataSet("NorthwindCustomerOrders")

下一步将建立数据库连接——从应用程序配置文件中读取数据库连接字符串。

  'Set up the connection to the database, reading from the App.config 

  Dim sqlCnn As New SqlConnection

  sqlCnn.ConnectionString = _

    ConfigurationSettings.AppSettings("ConnectDB")

  sqlCnn.Open()

有几种方法创建DataSet 中的DataTable对象来容纳关系数据。其中一种方法就是使用SQL语句(作为一个字符串变量)。这很容易办到,但是,通常你更希望使用存储过程来访问数据。下面代码中简单的SELECT语句无需任何参数——它返回表中完整的记录集合。

大多数ADO.NET.NET Framework中其他许多类一样拥有多个构造函数每个构造函数具有不同参数以便于你选择如何实例化对象。你可以传递一个内容为SQL语句的字符串和一个连接对象给SqlCommand对象的构造函数,实例化一个SqlCommand对象。

本文地址:http://com.8s8s.com/it/it44810.htm