ADO.NET 概述

ADO.NET是改进的ADO数据访问模型用于开发可扩展应用程序。他是专门为可伸缩性、无状态和XML核心的web而设计的。
 
ADO.NET使用一些ADO对象,如ConnectionCommand对象,也引入了一些新对象。关键的新对象包括DataSetDataReader,和DataAdapter
 
这种改进的ADO.NET和之前的数据架构的重要区别在于存在一个对象--DataSet对象--这是独立的不同于任何的数据存储。正因为如此,DataSet功能能够作为独立的实体。你可以将DataSet理解为总是断开连接对他包含的数据源和目标一无所知的记录集,在DataSet内部,就像一个数据库一样,有表,列,关系,约束,视图等等。
 
DataAdapter是一种连接到数据库来填充DataSet的对象。然后,连接回数据库更新数据,基于DatSet拥有数据的操作操作。在过去,数据处理一直是基于连接的。现在,为了使多层应用更高效,数据处理正在转向基于消息的方式。这种处理方式的核心是DataAdapter,提供了在DataSet和数据源之间用于检索和保存数据的桥梁。它是通过对数据存储请求正确的SQL指令实现的。
 
基于XML的DataSet对象提供了一个统一的编程模型,以至于适用于所有的数据存储:结构型,关系型,和层级型。他是通过对数据源“一无所知”,并且用他持有的集合和数据类型表示数据做到的。无论DataSet内部是什么数据源,都是通过调用同一套标准API暴露DataSet和相关对象的。

当DataSet对数据源不可知的时候,托管提供程序享有详尽的具体信息。托管提供程序的作用是连接,填充,并从数据存储持久化DataSet。OLE DB和SQL Server .NET框架部分的数据提供程序(System.Data.OleDb和System.Data.SqlClient)提供了四个基本对象:Command对象,Connection对象,DataReader对象和DataAdapter对象。在本文剩下的内容里,我们会遇到DataSet的每个部分,并且解释OLE DB/SQL Server .NET数据提供程序是什么,以及如何使用它们进行编码。

下面的章节会给你介绍一些改进后的对象,和一些新的对象。这些对象是: 
  • Connections. 用于连接和管理针对数据库的事务。
  • Commands. 用于发出针对数据库的SQL指令。
  • DataReaders. 用于从SQL Server数据源读取只进流的数据记录。
  • DataSets. 用于针对结构型数据,XML数据和关系型数据的存储,远程处理和编程。
  • DataAdapters. 用于推送数据到DataSet,并针对数据库协调数据。
 
注意:当处理数据库连接的时候,有两种不同的选项:SQL Server .NET 数据提供程序(System.Data.SqlClient)和OLE DB .NET 数据提供程序(System.Data.OleDb)。在这些实例中我们会使用SQL Server .NET数据提供程序。这些被直接写入Microsoft SQL Server。OLE DB .NET数据提供程序常用于任一OLE DB 提供者(它使用OLE DB)
 
Connections

Connections用于和数据库“沟通”,并且被声明为特定的提供程序级别,例如SQLConnection。Commands扫描连接然后结果集以流的形式被返回,这种流可以被DataReader对象读取,或者推入DataSet对象。

下面的例子演示了如何创建一个连接对象。Connections可以通过调用Open方法被显式打开,或者使用DataAdapter的时候被隐式打开。

 

若要确保连接始终关闭,请在 using 块内部打开连接,如下面的代码段所示。 这样可确保在代码退出代码块时自动关闭连接。

 
using (SqlConnection connection = new SqlConnection(connectionString))
{
connection.Open();
// Do work here; connection closed on following line.
}
 
 
Commands
 
Commands包含提交到数据库的信息,特定于提供程序的类比如SQLCommand。一个命令可以是一个存储过程调用,一个UPDATE语句,或者一个返回结果的语句。你也可以使用输入和输出参数,返回值作为命令的一部分。下面的示例演示了如何对Northwind数据库执行一条INSERT语句。
 

下面的示例创建一个 SqlConnection、一个 SqlCommand 和一个 SqlDataReader。 该示例读取所有数据,并将其写到控制台。 最后,示例在退出 Using 代码块时先后关闭 SqlDataReader 和 SqlConnection

 
private static void ReadOrderData(string connectionString)
{
string queryString =
"SELECT OrderID, CustomerID FROM dbo.Orders;";
using (SqlConnection connection = new SqlConnection(
connectionString))
{
SqlCommand command = new SqlCommand(
queryString, connection);
connection.Open();
SqlDataReader reader = command.ExecuteReader();
try
{
while (reader.Read())
{
Console.WriteLine(String.Format("{0}, {1}",
reader[], reader[]));
}
}
finally
{
// Always call Close when done reading.
reader.Close();
}
}
}
 
DataReaders
 
DataReader对象有点类似一种只读/只进的数据游标。DataReader API不但支持平级数据而且支持层级数据。数据库执行一条命令后会返回一个DataReader对象。返回的DataReader对象格式不同于一个记录集。比如,你可以在一个web页面使用DataReader显示搜索结果列表。
 

下面的示例创建一个 SqlConnection、一个 SqlCommand 和一个 SqlDataReader。 该示例读取全部数据,并将这些数据写到控制台窗口。 随后此代码关闭 SqlDataReader。 SqlConnection 在 using 代码块的结尾处自动关闭。

using System;
using System.Data;
using System.Data.SqlClient; class Program
{
static void Main()
{
string str = "Data Source=(local);Initial Catalog=Northwind;"
+ "Integrated Security=SSPI";
ReadOrderData(str);
} private static void ReadOrderData(string connectionString)
{
string queryString =
"SELECT OrderID, CustomerID FROM dbo.Orders;"; using (SqlConnection connection =
new SqlConnection(connectionString))
{
SqlCommand command =
new SqlCommand(queryString, connection);
connection.Open(); SqlDataReader reader = command.ExecuteReader(); // Call Read before accessing data.
while (reader.Read())
{
ReadSingleRow((IDataRecord)reader);
} // Call Close when done reading.
reader.Close();
}
} private static void ReadSingleRow(IDataRecord record)
{
Console.WriteLine(String.Format("{0}, {1}", record[], record[]));
} }
 
DataSets and DataAdapters
 
 
DataSets
 
DataSet对象和ADO RecordSet对象相似,但更强大,并且有一个重要区别:DataSet总是断开连接的。DataSet代表缓存数据,与数据库结构类似例如表,列,关系,和约束。然而,尽管DataSet可以也确实表现的更像一个数据库,最重要的请记住DataSet对象不直接和数据库交互,或者其他数据源。这使得开发人员无论使用什么数据源都可以始终使用一种一致的编程模型。数据从数据库,XML文件来,或者从用户输入来都可以放进DatSet对象。然后,当更改DataSet就可以被跟踪和验证之前更新数据源。DataSet对象的GetChanges方法实际上创建了第二个仅包含更改数据的DataSet。然后由DataAdapter(或其他对象)使用这个DataSet来更新原始数据源。
 
 
DataSet具备XML的特性,包括生产和消费XML数据和XML模式的能力。XML模式可以用来描述通过XML Web服务交换的模式。事实上,模式化DataSet实际上可以被编译为类型安全和完整的语句。
 
 
 
DataAdapters (OLEDB/SQL)
 
DataAdapter对象作为DataSet和数据源之间的桥梁。当使用Microsoft SQL Server数据库时,利用特定提供程序SqlDataAdapter(和他相关的SqlCommand和SqlConnection)可以提高整体的性能。对于其他支持OLE DB的数据库,你可以使用OleDbDataAdapter和他先关的OleDbCommand和OleDbConnection对象。
 
DataAdapter对象使用命令在DataSet完成变动后更新数据源。使用DataAdapter的Fill方法调用SELECT命令;使用Update方法对于每个更改行调用INSERT、UPDATE或者DELETE命令。你可以显示设置这些命令以便在运行时控制这些语句的使用解决变更,包括使用存储过程。对于特别的场景,CommandBuilder对象可以在运行时基于select语句生成这些语句。然而,运行时创建语句需要在服务器做额外的往返以便手机必须的源数据,所以在设计阶段显示的提供INSERT、UPDATE、和DELETE命令会导致更好的运行时性能。
 

下面的示例使用 SqlCommand、SqlDataAdapter 和 SqlConnection 从数据库中选择记录,并用选定的行填充 DataSet。 然后返回已填充的 DataSet。 为完成此任务,向该方法传递一个已初始化的 DataSet、一个连接字符串和一个查询字符串,后者是一个 Transact-SQL SELECT 语句。

 
private static DataSet SelectRows(DataSet dataset,
string connectionString,string queryString)
{
using (SqlConnection connection =
new SqlConnection(connectionString))
{
SqlDataAdapter adapter = new SqlDataAdapter();
adapter.SelectCommand = new SqlCommand(
queryString, connection);
adapter.Fill(dataset);
return dataset;
}
}
适应的记录映射到相应的命令。
 
 
 
图示:DataAdapter和DataSets
 
 
下面的示例说明了通过SELECT语句加载DataAdapter,然后在DataSet内部更新、删除以及添加一些记录。最后,通过DataAdapter返回那些对数据库源的更新。这些构造的DeleteCommand、InsertCommand与UpdateCommand被显示在页面。也举例说明了使用多个DataAdapter对象加载多个表(Customers和Orders)到DataSet。
 
 
小结:
  1. ADO.NET是适合于.NET框架的改进版的ADO。
  2. ADO.NET是在多层架构、无状态性与XML的情况下诞生的。DataSet和DataAdapter2个对象提供这些场景。
  3. ADO.NET可以被用于从流获取数据,或者缓存用于更新的数据。
  4. 在文档里有更多关于ADO.NET的资料。
  5. 请记住,你可以直接对数据库执行命令以便插入、更新,与删除数据。你没有必要为了插入、更新、或删除数据把它放入DataSet。
  6. 同样,你可以使用DataSet绑定到数据,浏览数据,以及操作数据关联。

原文地址:

http://quickstarts.asp.net/QuickStartv20/howto/doc/adoplus/overviewcontents.aspx

ADO.NET 快速入门(一):ADO.NET 概述的更多相关文章

  1. ADO.NET 快速入门(十五):ADO 应用转换为 ADO.NET

    这是一个已经移植到 .NET 的 ADO 应用的例子.也演示了单向.只读.快速 DataReader 的使用.它演示如何使用 DataView 类从 DataSet 获取一个 Table 和 操作一个 ...

  2. ADO.NET 快速入门(八):处理 Errors

    除了 Try/Catch 和 Exceptions 以外,新的 ADO.NET 数据框架也允许在 DataSet 的每行数据添加错误信息.如果 Updates 或者其他操作失败,SqlDataAdap ...

  3. ADO.NET 快速入门(七):使用数据库事务

    数据库事务用于控制数据提交到数据库.例如,在标准的账户程序,账户的借贷必须同时完成.由于电脑偶尔发生故障(电力中断.网络中断,等等),可能有些记录被更新或者添加,但是另外一些没有.为了避免这些情况,可 ...

  4. ADO.NET 快速入门(六):读写 XML

    ADO.NET 和 DataSet 可以读写 XML Schema 和 XML.获取更多信息,请参考 How do I...Use XML and the DataSet?   DataSet 的 S ...

  5. ADO.NET 快速入门(二):执行命令

    Commands发出针对数据库的数据存储动作.例如,你可以执行一条命令插入或者删除数据.获取更多从数据库移动数据相关的信息,请参考“Update a Database from a DataSet”. ...

  6. ADO.NET 快速入门(十四):使用 SQL Server 检索数据

    SqlDataReader 类提供了一种从数据源读取数据记录只进流的方法.如果想使用 OLE DB 接口的数据库或者 SQL Server7.0 之前的版本,请参考文章:使用 OLE DB 检索数据. ...

  7. ADO.NET 快速入门(十三):使用 OLE DB 检索数据

    OleDbDataReader 类提供了一种从数据源读取数据记录只进流的方法.如果想使用 SQL Server 7.0 或者更高版本,请参考文章:使用 SQL Server 检索数据.   OleDb ...

  8. ADO.NET 快速入门(十二):从 SQL Server 生成 XML 数据

    本文演示如何使用2种不同的方法从 SQL Server 生成 XML.   方法1:使用了 SqlCommand 的 ExecuteXmlReader 方法获取 XmlReader,然后使用 Data ...

  9. ADO.NET 快速入门(十一):连接池

    这个示例演示了如何构建一个到数据源的连接池.你可以通过连接池部署高性能的应用程序.本例中使用连接串创建连接池,并且由 SqlConnection 自动管理.   string connString; ...

随机推荐

  1. 开源Jabber(XMPP) IM服务器介绍

    一.摘要 这是我粗略读了一遍Jabber协议和相关技术文章后的产物,有些地方不一定准确.在文章中引用的一些代码来自www.jabber.org上的文章. 二. 什么是Jabber    Jabber就 ...

  2. Oracle DBA 的常用Unix参考手册(二)

    9.AIX下显示CPU数量    # lsdev -C|grep Process|wc -l10.Solaris下显示CPU数量# psrinfo -v|grep "Status of pr ...

  3. 解决WCF大数据量传输 ,System.Net.Sockets.SocketException: 远程主机强迫关闭了一个现有的连接

    开发中所用的数据需要通过WCF进行数据传输,结果就遇到了WCF大量传输问题 也就是提示System.Net.Sockets.SocketException: 远程主机强迫关闭了一个现有的连接 网上解决 ...

  4. Android Failure [INSTALL_FAILED_OLDER_SDK]

    今天编译工程发现 提示“ Failure [INSTALL_FAILED_OLDER_SDK]” 最后发现最小minSdkVersion 超过当前机器的版本,修改配置表中的minSdkVersion, ...

  5. ruby函数回调的实现方法

    以前一直困惑ruby不像python,c可以将函数随意传递,然后在需要的时候才去执行.其实本质原因是ruby的函数不是对象. 通过查阅资料发现可以使用如下方法: def func(a, b) puts ...

  6. SQL之50个常用的SQL语句

    50个常用的sql语句 Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(S#,C#,score) 成绩表 Teacher(T#,T ...

  7. Delphi 操作Word怎么控制光标的位置

    unit ControlWordS; interface uses Classes, Sysutils, Word97; type  TControlWord = class(TComponent)  ...

  8. 为cocos2d-x项目增加Lua支持

    开始为游戏增加Lua脚本支持,今天主要配置了一下开发环境:cocos2d-x 2.2.1,xcode5. 1. 创建cocos2d-x-lua项目 类似于创建C++项目,用以下命令即可: python ...

  9. 一起刷LeetCode1-Two Sum

    感觉有必要重新刷刷题了,为以后找工作做做准备,选择LeetCode+topcoder上的Data Science Tutorials, 争取每天晚上10:00开始刷一道,复习一下相关知识点. ---- ...

  10. es 的集群状态

    es的集群状态一共有三种 : green yellow red 状态是基于 碎片的 等级进行划分的 .