** 创建一个 ** ** DataSet **
假定你必须使用一个灵活的数据对象 , 这个对象允许你包含多个表 , 在表与表之间设定关系 , 以及向前或向后读取数据。
ADO.NET 中提供这些特性 —— 甚至更多 —— 的对象就是 ** DataSet ** ** 。 ** ** DataSet ** 是一种 断开式 _ (disconnected) _ 对象 , 这意味着一旦填充完数据 , 就不必保持数据库连接。 到数据库服务器的网络连接即使断开了也不会影响你的客户端应用程序使用数据库中的数据。这项技术的优势之一就是你释放数据库连接给其他用户,并且你的应用程序不再依赖于这个连接。然而,这也意味着数据库中的数据在你填充完 ** DataSet ** 后 可能改变,你应该意识到这个可能的差异。
数据访问层可以创建多个 ** DataSet ** 对象。 例如 , 你可能使用一个 ** DataSet ** 容纳静态数据以便填充用户界面上的一个列表框 , 或者你可能想使这些数据供多个用户访问。 另一个对象可能包含某个用户更新后的数据,将更改回传到数据库中的代码尽可能简单也是必要的。现在,你可以使用一个对象完成这所有的需求。
** 图 ** ** 1 ** ** 展示了 ** Northwind 数据库中各个表的结构 , 这些表包含了客户和订单信息。 你可以创建一个 ** DataSet ** ,作为这个数据库的结构镜像,或者完全改变它以适应你的应用程序需求。
** 图 ** ** 1 ** ** : ** ** 在 ** ** Northwind Customers DataSet ** ** 中使用的各个表的结构 **
下面的代码在 ** GetDataSet ** 方法中 定义了一个 ** DataSet ** , 包含了用户订单数据的全部列。 它带有一个 ** bSaveSchema ** 参数,用于指示该过程是否需要将 DataSet 对象的 XML 和 XML 架构的拷贝保存为磁盘文件,这些文件将在该应用程序的其他部分使用。
** 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 ** 对象。