ADO、DAO和ODBC详解

ADO是什么?我也不大说得清,只知道他是Active Data Object的缩写,可以当成是一种访问数据的方法吧,就象DAO,RDO一样,我想.但是,RDO和DAO都是在ODBC规程下开发的,ODBC为基础,ADO是在OLE DB规程下开发的,该规程据说是用C++开发的,所以有面向对象的特性.OLE DB,有两个概念,数据消费者和数据提供者,这些东东有些复杂,我就懒得去管他了:-)

1. ADO编程模式

1.1 接口概述

Connection(连接):Connection接口表示正在使用的数据源和ADO接口之间的连接.

Error(错误):由数据源返回的错误信息.

Command(命令):表示一个能被数据提供者处理的命令(查询或语句),用他可以返回一个Recordset记录集或执行一个查询动作.

Parameter(参数):表示传给Command的参数.

Recordset:这个最复杂,但是功能最强,"包含数据的游标",至于"游标",我把他理解成在内存中的数组,不知对不对.

Field( 字段 ):Recordset 中的某一列数据 .

1.2 接口的创建
ADO
接口与其他概念中的对象不一样的是,他不须派生,大多数对象都可以直接创建(FieldError除外),ADO,没有对象的分级结构.
下面是一个例子:

(译注,这个例子我在SQL Server上没有成功,我的IIS4.0,我用下述方法:

扫描二维码关注公众号,回复: 2222640 查看本文章

1.3 对象的作用范围
我们都知道,HTTP协议是无状态的协议,你不能指望在调用了这个HTML文件后保存一个状态,供调下一个文件时使用.ASP却可以实现,我们在第六讲中提到Session对象,他缺省地能保持一个会话20分钟,我们就能利用这一点维持数据库连接.一个典型的应用是我们一次返回数据库的20条记录.
我们可以这么做:

2. 使用ADO

2.1 创建DSN
DSN
的创建,我已在前面文章讲过.

2.2 安全考虑
ASP
曾经有一个安全漏洞,你可以在ASP文件的URL最后简单地加一个句号(.),或者加上::$DATA,例如:http://127.0.0.1/asp/test.asp::$DATA你会看到浏览器显示的不是经过处理的结果,而是ASP源代码!(我去试过一些网站,包括微软的,已经不行了^_^,只有我自己的PWS还可以看到)

3. Connection接口

3.1Connection接口是数据源的一个开放连接.

你可以把他看成是DAO中的Database对象,或者RDO中的doConnection.

在你用ASP文件中的Connection接口做任何事之前,必须首先创建他.注意创建与打开他是两回事.下面是创建代码:

Set mconn=Server.CreateObject("ADODB.Connection")
然后打开 :
mconn.Open "ODBC;DATABASE=pubs;UID=sa;DSN=pub"
(
译注 : 我还是建议用下面的方法 :
mconn.Open "dsnname","username","password"WhiteSaillor)

3.2 Connection的方法
.Open方法
用来初始化一个连接.只有等到你使用了Connection对象的Open方法,Connection对象才真正存在.(?我不大懂)
.Close
方法当你调用了Close方法时,就停止了与数据提供者的连接,并释放与之关联的系统资源.但并没有释放Connection对象本身.(也就是说,你可以又调用Open方法连接新的数据源)

.BeginTrans方法
.ComitTrans
方法
.RollbackTrans
方法
.Execute
方法

Connection对象也能用来执行SQL语句及存储过程,但有一点须说明的是,他返回的信息是最基本的游标,只能读和只能向前移动的游标.

调用方法:
Set RecordSet=Connection.Execute(CommandText,RecordAffected,Options)
其中,CommandText是一个串,可以用一个标准的SQL语句,RecordAffected是一个变量,返回命令执行时影响的记录数,Options参数定义传给Execute的命令串的类型可为:

1.adCmdText:表明参数串是SQL
2.adCmdTable:
是表名
3.adCmdStoreProc:
是数据提供者知道的存储过程
4.adCmdUnknown:
不清楚

3.3 Connection的属性
.Attributes,
定义了处理事物的方法
.CommandTimeout,
定义允许对数据源操作的命令终止并产生一个错误的等待时间
.ConnectionString,
相当与调用Execute时给的第一个参数
.ConnectionTimeout,
定义在放弃连接并产生一个错误前等待数据源响应的时间
.DefaultDatabase,
定义在连接中使用的缺省数据库
.Provider,
返回连接的数据提供者的名字
--
10.8.1
什么是DAO
DAO(Database Access Object)使用Microsoft Jet数据库引擎来访问数据库。
Microsoft Jet
为象AccessVisual Basic这样的产品提供了数据引擎。
 与ODBC一样,DAO提供了一组API供编程使用。MFC也提供了一组DAO,封装了底层的API,从而大大简化了程序的开发。利用MFCDAO类,用户可以编写独立于DBMS的应用程序。
DAO是从Visual C++4.0版开始引入的。一般地讲,DAO类提供了比ODBC类更广泛的支持。一方面,只要有ODBC驱动程序,使用Microsoft JetDAO就可以访问ODBC数据源。另一方面,由于DAO是基于Microsoft Jet引擎的,因而在访问Access数据库(*.MDB文件)时具有很好的性能。

10.8.2 DAOODBC的相似之处
DAO
类与ODBC类相比具有很多相似之处,这主要有下面几点:
二者都支持对各种ODBC数据源的访问。虽然二者使用的数据引擎不同,但都可以满足用户编写独立于DBMS的应用程序的要求。
DAO
提供了与ODBC功能相似的MFC类。例如,DAOCDaoDatabase类对应ODBCCDatabase类,CDaoRecordset对应CRecordsetCDaoRecordView对应CRecordViewCDaoException对应CDBException。这些对应的类功能相似,它们的大部分成员函数都是相同的。

AppWizardClassWizard对使用DAOODBC对象的应用程序提供了类似的支持。
  由于DAOODBC类的许多方面都比较相似,因此只要用户掌握了ODBC,就很容易学会使用DAO。实际上,用户可以很轻松地把数据库应用程序从ODBC移植到DAO
Visual C++随盘提供了一个名为DaoEnrol的例子,该例实际上是Enroll的一个DAO版本。读者可以打开DaoEnrol工程看一看,它的源代码与Enroll的极为相似。
读者可以按照建立Enroll的步骤来建立DaoEnrol,其中只有若干个地方有差别,这主要有以下几点:
选取的数据源不同。在用AppWizard创建DaoEnrol时,以及在用ClassWizard创建CDaoRecordset类的派生类时,在Database Options对话框中应该选择DAO而不是ODBC。而且DAO的数据源是通过选择一个.MDB文件来指定的,即点击"..."按钮后在文件对话框中选择要访问的.MDB文件。
记录集的缺省类型不同。ODBC记录集的缺省类型是快照(Snapshot),而DAO则是动态集(Dynaset)
参数化的方式不同。DAO记录集的m_strFilterm_strSort中的参数不是"?"号,而是一个有意义的参数名。例如,在下面的过滤器中有一个名为CourseIDParam的参数。
m_pSet->m_strFilter ="CourseID = CourseIDParam";
DoFieldExchange函数中,有下面两行:
pFX->SetFieldType(CDaoFieldExchange::param);
DFX_Text(pFX, _T("CourseIDParam"), m_strCourseIDParam);
DFX
函数的第二个参数也是CourseIDParam
处理异常的方式不同。例如,在删除记录时,对异常的处理如下所示:
try
{
m_pSet->Delete();
}
catch(CDaoException* e)
{
AfxMessageBox(e->
m_pErrorInfo->m_strDescription);
e->Delete();
}
  除了上述差别外,AppWizardClassWizard也隐藏了一些细微的不同之处,例如,DAO记录集是使用是DFX数据交换机制(DAO record field exchange)而不是RFX,在DAO记录集的DoFieldExchange中使用的是DFX函数而不是RFX函数。

10.8.3 DAO的特色
DAO可以通过ODBC驱动程序访问ODBC数据源。但DAO是基于Microsoft Jet引擎的,通过该引擎,DAO可以直接访问AccessFoxProdBASEParadoxExcelLotus WK等数据库。CDaoDatabase类可以直接与这些数据库进行连接,而不必在ODBC管理器中注册DSN。例如,下面的代码用来打开一个FoxPro数据库:

CDaoDatabase daoDb;
daoDb.Open( "",FALSE,FALSE,"FoxPro 2.5;DATABASE=c:\\zyf");
CDaoDatabase::Open
函数用来连接某个数据库,该函数的声明为:
virtual void Open( LPCTSTR lpszName, BOOL bExclusive = FALSE, BOOL
bReadOnly = FALSE, LPCTSTR lpszConnect = _T("") );
throw( CDaoException, CMemoryException );

  参数bExclusive如果为TRUE,则函数以独占方式打开数据库,否则就用共享方式。如果bReadOnlyTRUE,那么就以只读方式打开数据库。如果要打开一个Access数据库,则可以在lpszName参数中指定MDB文件名。如果要访问非Access数据库,则应使该参数为"",并在lpszConnect中说明一个连接字符串。连接字符串的形式一般为 "数据库类型;DATABASE=路径(文件)",例如 "dBASE III;DATABASE=c:\\MYDIR"

Open函数也可以打开一个ODBC数据源,但这需要相应的ODBC驱动程序,并需要在ODBC管理器中注册DSN。此时lpszConnect的形式为 "ODBC;DSN=MyDataSource"。显然,用DAO访问象FoxPro这样的数据库时,直接打开比把它当作ODBC数据源打开要省事。

  支持DDLDAO对数据库编程良好支持的一个重要体现。DDL(Data Definition Language)SQL术语中叫做"数据定义语言",它用来完成生成、修改和删除数据库结构的操作。ODBC类只支持DML(DataManipulation Language,数据操作语言),不支持DDL,所以用ODBC类只能完成数据的操作,不能涉及数据库的结构。要执行DDL操作,只有通过ODBC API。而DAO类同时提供了对DMLDDL的支持,这意味着程序可以使用DAO类方便的创建数据库及修改数据库的结构。

  与ODBC相比,DAO提供了一些新类来加强其功能,这些新类包括:CDaoTableDef类提供了对表的结构的定义。调用CDaoTableDef::Open可以获得表的结构定义。调用CDaoTableDef::Create可以创建一张新表,调用CDaoTableDef:: CreateField可为表添加字段,调用CDaoTableDef::CreateIndex可以为表添加索引。调用CDaoTableDef::Append可以把新创建的表保存到数据库中。

CDaoQueryDef类代表一个查询定义(Querydefinition),该定义可以被存储到数据库中。

CDaoWorkspace提供了数据工作区(Workspace)。一个工作区可以包含几个数据库,工作区可以对所属的数据库进行全体或单独的事务处理,工作区也负责数据库的安全性。如果需要,程序可以打开多个工作区。

DAO的另一个重要特色在于它对Access数据库提供了强大的支持。由于DAO是基于Microsoft Jet引擎的,所以DAO肯定要在Access数据库上多作一些文章。例如,调用CDaoDatabase::Create可以直接建立一个MDB文件,代码如下所示:
m_db.Create("C:\\MYDIR\\MYDB.MDB");
利用AppWizardClassWizard,用户可以方便地开发出性能优良的基于DAOAccess数据库应用程序。

10.8.4 ODBC还是DAO

由于DAO可以访问ODBC数据源,下面几条可以作为DAO替代ODBC的理由:
在某些情况下可以获得更好的性能,特别是在访问Microsoft Jet.MDB)数据库时。

ODBC兼容

DAO允许数据有效检查

DAO允许用户说明表与表之间的关系

  当然,DAO的出现并不意味着ODBC已经过时了。如果用户的工作必须严格限于ODBC数据源,尤其是在开发Client/Server结构的应用程序时,用ODBC有较好的性能。

猜你喜欢

转载自blog.csdn.net/weixin_39345003/article/details/80952441