什么是DAO Database Access Object
什么是DAO Database Access Object
发布时间:2016-12-26 来源:查字典编辑
摘要:DAO(DatabaseAccessObject)使用MicrosoftJet数据库引擎来访问数据库。MicrosoftJet为象Acces...

DAO(DatabaseAccessObject)使用MicrosoftJet数据库引擎来访问数据库。

MicrosoftJet为象Access和VisualBasic这样的产品提供了数据引擎。

与ODBC一样,DAO提供了一组API供编程使用。MFC也提供了一组DAO类,封装了

底层的API,从而大大简化了程序的开发。利用MFC的DAO类,用户可以编写独立于

DBMS的应用程序。

DAO是从VisualC++4.0版开始引入的。一般地讲,DAO类提供了比ODBC类更广

泛的支持。一方面,只要有ODBC驱动程序,使用MicrosoftJet的DAO就可以访问

ODBC数据源。另一方面,由于DAO是基于MicrosoftJet引擎的,因而在访问

Access数据库(即*.MDB文件)时具有很好的性能。

10.8.2DAO和ODBC的相似之处

DAO类与ODBC类相比具有很多相似之处,这主要有下面几点:

二者都支持对各种ODBC数据源的访问。虽然二者使用的数据引擎不同,但都可以满

足用户编写独立于DBMS的应用程序的要求。

DAO提供了与ODBC功能相似的MFC类。例如,DAO的CDaoDatabase类对应ODBC的

CDatabase类,CDaoRecordset对应CRecordset,CDaoRecordView对应CRecordView

,CDaoException对应CDBException。这些对应的类功能相似,它们的大部分成员

函数都是相同的。

AppWizard和ClassWizard对使用DAO和ODBC对象的应用程序提供了类似的支持。

由于DAO和ODBC类的许多方面都比较相似,因此只要用户掌握了ODBC,就很容

易学会使用DAO。实际上,用户可以很轻松地把数据库应用程序从ODBC移植到DAO。

VisualC++随盘提供了一个名为DaoEnrol的例子,该例实际上是Enroll的一个

DAO版本。读者可以打开DaoEnrol工程看一看,它的源代码与Enroll的极为相似。

读者可以按照建立Enroll的步骤来建立DaoEnrol,其中只有若干个地方有差别,这

主要有以下几点:

选取的数据源不同。在用AppWizard创建DaoEnrol时,以及在用ClassWizard创建

CDaoRecordset类的派生类时,在DatabaseOptions对话框中应该选择DAO而不是

ODBC。而且DAO的数据源是通过选择一个.MDB文件来指定的,即点击“...”按钮后

在文件对话框中选择要访问的.MDB文件。

记录集的缺省类型不同。ODBC记录集的缺省类型是快照(Snapshot),而DAO则是动

态集(Dynaset)。

参数化的方式不同。DAO记录集的m_strFilter和m_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();

}

除了上述差别外,AppWizard和ClassWizard也隐藏了一些细微的不同之处,例

如,DAO记录集是使用是DFX数据交换机制(DAOrecordfieldexchange)而不是

RFX,在DAO记录集的DoFieldExchange中使用的是DFX函数而不是RFX函数。

10.8.3DAO的特色

DAO可以通过ODBC驱动程序访问ODBC数据源。但DAO是基于MicrosoftJet引擎

的,通过该引擎,DAO可以直接访问Access、FoxPro、dBASE、Paradox、Excel和

LotusWK等数据库。CDaoDatabase类可以直接与这些数据库进行连接,而不必在

ODBC管理器中注册DSN。例如,下面的代码用来打开一个FoxPro数据库:

CDaoDatabasedaoDb;

daoDb.Open(“”,FALSE,FALSE,"FoxPro2.5;DATABASE=c:zyf");

CDaoDatabase::Open函数用来连接某个数据库,该函数的声明为:

virtualvoidOpen(LPCTSTRlpszName,BOOLbExclusive=FALSE,BOOL

bReadOnly=FALSE,LPCTSTRlpszConnect=_T(""));

throw(CDaoException,CMemoryException);

参数bExclusive如果为TRUE,则函数以独占方式打开数据库,否则就用共享方

式。如果bReadOnly为TRUE,那么就以只读方式打开数据库。如果要打开一个

Access数据库,则可以在lpszName参数中指定MDB文件名。如果要访问非Access数

据库,则应使该参数为“”,并在lpszConnect中说明一个连接字符串。连接字符

串的形式一般为“数据库类型;DATABASE=路径(文件)”,例如“dBASEIII;

DATABASE=c:MYDIR”

Open函数也可以打开一个ODBC数据源,但这需要相应的ODBC驱动程序,并需要

在ODBC管理器中注册DSN。此时lpszConnect的形式为“ODBC;DSN=MyDataSource”

。显然,用DAO访问象FoxPro这样的数据库时,直接打开比把它当作ODBC数据源打

开要省事。

支持DDL是DAO对数据库编程良好支持的一个重要体现。DDL(Data

DefinitionLanguage)在SQL术语中叫做“数据定义语言”,它用来完成生成、修

改和删除数据库结构的操作。ODBC类只支持DML(DataManipulationLanguage,数

据操作语言),不支持DDL,所以用ODBC类只能完成数据的操作,不能涉及数据库的

结构。要执行DDL操作,只有通过ODBCAPI。而DAO类同时提供了对DML和DDL的支持

,这意味着程序可以使用DAO类方便的创建数据库及修改数据库的结构。

与ODBC相比,DAO提供了一些新类来加强其功能,这些新类包括:

CDaoTableDef类提供了对表的结构的定义。调用CDaoTableDef::Open可以获得表的

结构定义。调用CDaoTableDef::Create可以创建一张新表,调用CDaoTableDef::

CreateField可为表添加字段,调用CDaoTableDef::CreateIndex可以为表添加索引

。调用CDaoTableDef::Append可以把新创建的表保存到数据库中。

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

库中。

CDaoWorkspace提供了数据工作区(Workspace)。一个工作区可以包含几个数据库,

工作区可以对所属的数据库进行全体或单独的事务处理,工作区也负责数据库的安

全性。如果需要,程序可以打开多个工作区。

DAO的另一个重要特色在于它对Access数据库提供了强大的支持。由于DAO是基

于MicrosoftJet引擎的,所以DAO肯定要在Access数据库上多作一些文章。例如,

调用CDaoDatabase::Create可以直接建立一个MDB文件,代码如下所示:

m_db.Create(“C:MYDIRMYDB.MDB”);

利用AppWizard和ClassWizard,用户可以方便地开发出性能优良的基于DAO的

Access数据库应用程序。

10.8.4ODBC还是DAO

由于DAO可以访问ODBC数据源,下面几条可以作为DAO替代ODBC的理由:

在某些情况下可以获得更好的性能,特别是在访问MicrosoftJet(.MDB)数据库

时。

与ODBC兼容

DAO允许数据有效检查

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

当然,DAO的出现并不意味着ODBC已经过时了。如果用户的工作必须严格限于

ODBC数据源,尤其是在开发Client/Server结构的应用程序时,用ODBC有较好的性

能。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新应用技巧学习
热门应用技巧学习
网页设计子分类