创建一个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对象。