ADONET是微软的Microsoft ActiveX Data Objects (ADO)的下一代产品是在微软的NET中创建分布式和数据共享应用程序的应用程序开发接口(API)
ADONET能被用在任何用户的应用程序需要和OLE DBcompliant的数据源连接和通讯例如Microsoft SQL Server
同时ADONET又保持着与以前的ADO模型有关的一些主要概念它已经被极大的完善并从不同的信息来源提供途径去获得结构化的数据一个平台文本文件从数据库管理系统获得的相关数据或者是分级的XML数据然而所有都按照一个相容的标准化的设计模型来执行
这篇文章意在简要的介绍ADONET的关键特性重点讲述了在关系数据库管理系统(rdbms)中访问数据
快速浏览
SQL Server (及更新版本)以及可以通过 OLE DB 提供者进行访问的任何数据源这些又称为被管理的提供者(Managed Provider)NET框架的数据存取API提供了两种方式分别识别并处理两种类型的数据源SQL Server (及更新版本)和可以通过 OLE DB 提供者进行访问的任何数据源SQL(SystemDataSQL)库可以直接联结到SQL Server的数据而ADO (SystemDataADO)库可用于其他通过OLE DB 提供者进行访问的任何数据源
SQL Server被管理的提供者在MS SQL Server 或以后的版本中使用叫做tabulardata stream的专用协议而没有使用OLE DB ADO 或 ODBC
ADONET被管理的提供者能够在这些OLE DB 提供者下工作
驱动程序 Driver
提供者 Provider
SQLOLEDB
SQL OLE DB Provider
MSDAORA
Oracle OLE DB Provider
JOLT
Jet OLE DB Provider
MSDASQL/SQLServer ODBC
SQL Server ODBC Driver via OLE DB for ODBC Provider
MSDASQL/Jet ODBC
Jet ODBC Driver via OLE DB Provider for ODBC Provider
现在ADONET还不支持 MSDASQL/Oracle ODBC Driver(ORACLE OLE DB DRIVER FOR ODBC)
以下章节将介绍每个被管理的提供者都可用的ADONET的核心组件
Connections连接和管理数据库事务
Commands向数据库发送的命令
DataReaders直接读取流数据
DateSets 和 DateSetCommands对驻留内存中的数据进行存储和操作
核心的ADONET功能基本上可以被概括为如下内容
Connection对象在Web页面和数据库间建立连接Commands对象向数据库提供者发出命令返回的结果以一种流的方式贯穿于这些连接中结果集可以用DataReaders快速的读取也可以储存到驻留内存的DateSets对象中然后通过DateSetCommands对象让用户在数据集中访问和操作记录开发者可以用过DateSet内置的方法在基础的数据源上去处理数据集
为了使用NET框架中的被管理提供者需要把下面的名空间(namespaces)包括到aspx页面中
SQL被管理的提供者
<%@ Import Namespace=SystemDataSQL %>
ADO被管理的提供者
<%@ Import Namespace=SystemDataADO %>
Connections
微软在NET框架中提供了两个Connection对象以建立连接到特定的数据库SQLConnection和 ADOConnectionConnection对象能在已经创建的连接上通过调用open的方法来被明确的打开连接下面的代码片断演示了用任一提供者创建和打开连接
SQLConnection
[C#]
String connectionString = server=localhost; uid=sa; pwd=; database=northwind;
SQLConnection myConn = new SQLConnection(connectionString);
myConnOpen();
[VB]
Dim connectionString As String = _
m connectionString As String = _
server=localhost; uid=sa; pwd=; database=northwind
Dim myConn As SQLConnection = New SQLConnection(connectionString)
myConnOpen
ADOConnection
[C#]
String connectionString = Provider=SQLOLEDB; Data Source=localhost; uid=sa; pwd=; Initial Catalog=Northwind;
ADOConnection myConn = new ADOConnection(connectionString);
myConnOpen();
[VB]
Dim connectionString As String = _
ost; uid=sa; pwd=; Initial Catalog=Northwind;
ADOConnection myConn = new ADOConnection(connectionString);
myConnOpen();
[VB]
Dim connectionString As String = _
Provider=SQLOLEDB; Data Source=localhost; & _
uid=sa; pwd=; Initial Catalog=Nohwind
Dim myConn As ADOConnection = New ADOConnection(connectionString)
myConnOpen()
Commands
在建立了连接以后下一步要做的就是对数据库运行的SQL语句最简单直接的方法是通过ADO和SQL命令对象来实现
Command对象可以给予提供者一些该如何操作数据库信息的指令
一个命令(Command)可以用典型的SQL语句来表达包括执行选择查询(select query)来返回记录集执行行动查询(action query)来 更新(增加编辑或删除)数据库的记录或者创建并修改数据库的表结构当然命令(Command)也可以传递参数并返回值
Commands可以被明确的界定或者调用数据库中的存储过程接下来的小段代码证明了在建立连接之后如何去发出一个Select命令
SQLCommand
[C#]
String SQLStmt = SELECT * FROM Customers;
SQLCommand myCommand = new SQLCommand(SQLStmt myConn);
[VB]
Dim SQlStmt As String = SELECT * FROM Customers
Dim myCommand As SQLCommand = New SQLCommand(SQLStmt myConn)
ADOCommand
[C#]
String SQLStmt = SELECT * FROM Customers;
ADOCommand myCommand = new ADOCommand(SQLStmt myConn);
[VB]
Dim SQlStmt As String = SELECT * FROM Customers
Dim myCommand As ADOCommand = New ADOCommand(SQLStmt myConn)
DataReaders
当你处理大量数据的时候大量内存的占用会导致性能上的问题例如一个连接(connection)用传统的ADO Recordset对象去读行数据库的记录就必须为这行记录将内存分配给这个连接直至这个连接的生命周期结束如果有用户在同一时间对同一计算机进行同样的操作内存被过度的使用就会成为关键性的问题
为了解决这些问题NET框架包括了DataReaders对象而这个对象仅仅从数据库返回一个只读的仅向前数据流而且当前内存中每次仅存在一条记录
DataReader接口支持各种数据源比如关系数据和分级数据DataReader可以适用于在运行完一条命令仅需要返回一个简单的只读记录集
下面的代码片断阐述了怎么样声明变量指向一个DataReader对象的实例还包括代码执行时Command对象产生的结果当调用Command对象执行方法时Command对象必须已经被创建和作为参数来传递继续上面的例子
SQLDataReader
[C#]
SQLDataReader myReader = null;
myCommandExecute(out myReader);
[VB]
Dim myReader As SQLDataReader = Nothing
myCommandExecute(myReader)
ADODataReader
[C#]
ADODataReader myReader = null;
myCommandExecute(out myReader);
[VB]
Dim myReader As ADODataReader = Nothing
myCommandExecute(myReader)
接下来这步是一个使用DataReader的简单格式
[C#]
While (myReaderRead()) {
[C#]
While (myReaderRead()) {
// do your thing with the current row here
}
[VB]
While myReaderRead
do your thing with the current row here
End While
下面的例子展示了迄今为止我们所讨论的内容建立一个到SQL数据源的连接对于连接的发送select命令用DataReader对象来保存返回的结果然后通过循环DataReader取得数据
下面是用C#写的完整代码
<%@ Import Namespace=SystemData %>
<%@ Import Namespace=SystemDataSQL %>
<html>
<head>
<script language=C# runat=server>
public SQLDataReader myReader;
public String html;
protected void Page_Load(Object Src EventArgs E ) {
SQLConnection mySQLConnection = new SQLConnection(server=localhost;uid=sa;pwd=;database=northwind);
SQLCommand mySQLCommand = new SQLCommand(select * from customers mySQLConnection);
try {
mySQLConnectionOpen();
mySQLCommdExecute(out myReader);
Execute(out myReader);
html=<Table>;
html+=<TR>;
html+=<TD