技术开发 频道

ASP.NET 2.0 中的数据访问

DataAdapter 和 DataSet

虽然连接数据库的应用程序使用 DataReader 就已足够,但是,DataReader 不能很好地支持数据库访问的断开连接模型。而 DataAdapterDataSet 类则满足了这一需求。

DataSet 是 ADO.NET 断开连接体系结构中主要的数据存储工具。填充 DataSet 时,并非通过 Connection 对象将 DataSet 直接连接到数据库。您必须创建一个 DataAdapter 来填充 DataSetDataAdapter 连接数据库,执行查询并填充 DataSet。当 DataAdapter 调用 FillUpdate 方法时,在后台完成所有的数据传输。每个 .NET Framework 的数据提供程序都有一个 DataAdapter 对象。

一个 DataSet 代表一组完整的数据,包括表格、约束条件和表关系。DataSet 能够存储代码创建的本地数据,也能存储来自多个数据源的数据,并断开到数据库的连接。

DataAdapter 能控制与现有数据源的交互。DataAdapter 也能将对 DataSet 的变更传输回数据源中。下列代码说明使用 DataSet 典型情况。


[Visual Basic] Dim nwindConn As SqlConnection = _ New SqlConnection("Data Source=localhost;" & _ "Integrated_Security=SSPI;Initial Catalog=northwind") Dim selectCMD As SqlCommand = _ New SqlCommand("SELECT CustomerID, CompanyName FROM " & _ "Customers", nwindConn) selectCMD.CommandTimeout = 30 Dim custDA As SqlDataAdapter= New SqlDataAdapter custDA.SelectCommand= selectCMD Dim custDS As DataSet= New DataSet custDA.Fill(custDS, "Customers") nwindConn.Close() [C#] SqlConnection nwindConn = new SqlConnection("Data Source=localhost;" + "IntegratedSecurity=SSPI;Initial Catalog=northwind"); SqlCommand selectCMD = new SqlCommand("SELECT CustomerID, CompanyName FROM Customers", nwindConn); selectCMD.CommandTimeout = 30; SqlDataAdaptercustDA = new SqlDataAdapter(); custDA.SelectCommand= selectCMD; nwindConn.Open(); DataSetcustDS = new DataSet(); custDA.Fill(custDS, "Customers"); nwindConn.Close();

在以上代码中:

1.

创建了一个 SQLConnection 来连接 SQL Server 数据库。

2.

创建了一个 SQLCommand 来查询 Customers 表格。

3.

创建了一个 DataAdapter 来执行 SQLCommand 和数据操作的连接部分。

4.

DataAdapter 可以创建一个 DataSetDataSet 是数据操作的断开连接部分,并且能绑定到 ASP.NET 2.0 的各种 Web 控件。

一旦创建了 DataSet,就能够将它绑定到任何数据识别的控件,方法是通过控件的 DataSource 属性和 DataBind() 方法。不幸的是,如果数据发生更改,您不得不再次调用 DataBind(),将控件重新绑定到数据集。因此,ASP.NET 1.x 开发人员不得不考虑调用绑定方法的精确时间和位置。开发出正确的同步方法和同步事件是相当困难的。

由于存在数据源的概念,ASP.NET 2.0 极大地简化了创建、绑定 DataSet 以及保持数据同步的全部过程。

ASP.NET 2.0

ASP.NET 2.0 从几个方面极大地改进了基本模型。最突出的一方面是,通过 DataSource 隐藏了创建 SQLCommand、生成 DataAdapter 和填充 DataSet 的过程,或者由数据绑定向导自动配置这个过程。

Configure DataSource Wizard 生成的代码能够连接数据源(数据库、平面文件、XML、对象),创建查询,并允许开发人员以简单的几个步骤指定参数。

一旦创建了数据源,下一步就是将数据源连接到一个控件。这里的“连接”就是所谓的数据绑定。从数据源提取的值能够连接到控件属性或作为表格、列表或网格中的值使用,这些操作都无需编写任何代码。

ASP.NET 数据控件

ASP.NET 1.1 是为使用 ADO.NET API 和简化数据访问而设计的。ADO.NET 2.0 通过新增的一组控件和向导进一步简化了数据访问过程和编写代码的数量,这些控件和向导是针对数据识别的应用程序,为提高开发速度和简化开发过程而设计的。

DataSource 控件

新的 ASP.NET 2.0 数据访问系统的核心是 DataSource 控件。一个 DataSource 控件代表一个备份数据存储(数据库、对象、xml、消息队列等),能够在 Web 页面上声明性地表示出来。页面并不显示 DataSource,但是它确实可以为任何数据绑定的 UI 控件提供数据访问。为了支持 DataSource 并使用自动数据绑定,利用一个事件模型以便在更改数据时通知控件,各种 UI 控件都进行了重新设计。此外,数据源还提供了包括排序、分页、更新、删除和插入在内的功能,执行这些功能无需任何附加代码。

最终,所有 DataSource 控件公开一个公共接口,因此,数据绑定控件无需了解连接细节(即连接到一个数据库还是一个 XML 文件)。每个 DataSource 还公开了特定于数据源的属性,因而对开发人员而言更为直观。例如,SqlDataSource 公开了 ConnectionStringSelectCommand 属性,而 XMLDataSource 则公开了定义源文件和任何架构的属性。在底层,所有数据源都创建特定于提供程序的基础 ADO.NET 对象,该对象是检索数据所需的。

创建一个 DataSource

在ASP.NET 2.0 中,DataSource 的子类是新增的数据控件中功能最强大的。它们提供了到数据库、XML 文件或其他数据源的声明性配置连接。使用控件从数据源检索和更新数据无需添加任何自定义代码。Configure DataSource Wizards 的图形化界面允许程序员定义相应的细节来配置数据源,几个简单的步骤就可以完成。ASP.NET 2.0 自动生成代码来连接资源,如果合适,创建基于参数的查询。自动生成的代码结果存储在一个 .ASPX 文件中。例如,在 .ASPX 文件中存储的 SQLDataSource 代码包含连接字符串的属性和 SQL 语句的属性。

<asp:sqldatasource id="SqlDataSource1" runat="server" selectcommand="select customerid, companyname from customers" providername="System.Data.OleDb" connectionstring="Provider=SQLOLEDB.1;Integrated Security=SSPI; Initial Catalog=Northwind; Data Source=localhost; Auto Translate=True; Use Encryption for Data=False> </asp:sqldatasource>

当然,开发人员能够根据需要修改这些代码。例如,可以将提供程序名移动到 web.config 文件或其他中心位置。

数据源类型

ASP.NET 2.0 提供了几个独特的数据源对象,用于为数据绑定控件构造一个公共接口框架。数据源的对象用于操作不同的基础结构(从数据库、内存中的对象到 XML 文件),为控件提供抽象数据操作功能。

AccessDataSource

如果在应用程序中使用 Microsoft Access 数据库,则能够通过 System.Web.UI.WebControls.AccessDataSource 执行插入、更新和删除数据的操作。Access 数据库是提供基本关系存储的最小数据库。因为使用起来既简单又方便,所以许多小型的 Web 站点通过 Access 形成数据存储层。虽然 Access 不提供像 SQL Server 这样的关系数据库的所有功能,但是其简单性和易用性使 Access 非常适合应用于原型开发和快速应用程序开发 (RAD)。

SqlDataSource

为了提供一个更加健壮的数据库,综合利用 Microsoft SQL Server 提供的广泛功能,ASP.NET 2.0 提供了 SQLDataSourceSQLDataSource 的配置比 AccessDataSource 的更为复杂,SQLDataSource 用于企业级应用程序,这些应用程序需要一个真正的数据库管理系统 (DBMS) 所拥有的功能。

ObjectDataSource

System.Web.UI.WebControls.ObjectDataSource 用于实现一个数据访问层,从而提供更好的封装和抽象。ObjectDataSource 控件支持绑定到一个特定的数据层,而非绑定到一个数据库,其绑定方式与使用其他控件绑定数据库的方式相同。ObjectDataSource 控件能够绑定到任何一个方法,该方法返回一个 DataSet 对象或 IEnumerable 对象(例如,一个 DataReader 或类集合)。

<asp:objectdatasource id="ObjectDataSource" runat="server" typename="DAL.Customers" selectmethod="GetOrders"> </asp:objectdatasource>

ObjectDataSource 控件使用 Web 服务代理的方式与使用数据访问层的方式完全相同。换句话说,ObjectDataSource 处理设计正确的 Web 服务与处理一个关系数据库的方式相同。

DataSetDataSource

System.Web.UI.WebControls.DataSetDataSource 控件允许使用 XML 列表数据。列表数据以行和列排列。

<?xml version="1.0"?> <collection> <book> <title>cosmos</title> <author>carl sagan</author> <publisher>ballantine books</publisher> </book> <book> <title>catwings</title> <author>ursula k. le guin</author> <publisher>scholastic</publisher> </book> </collection>
要使用数据,只需设置 DataFile 属性,使其指向 XML 文件。
<asp:datasetdatasource id="Datasetdatasource1" runat="server" datafile="collection.xml" />

数据源能够连接到任何列表控件,例如 DataGrid

0
相关文章