DAO

生活百科 2023-01-26 10:45生活百科www.aizhengw.cn

DAO

DAO(Data Access Object) 数据访问对象是一个面向对象的资料库接口,它显露了 Microsoft Jet 资料库引擎(由 Microsoft Access 所使用),并允许 Visual Basic 开发者通过 ODBC 像直接连线到其他资料库一样,直接连线到 Access 表。DAO 最适用于单系统应用程式或小範围本地分布使用。

基本介绍

  • 中文名资料库访问对象
  • 外文名Data Access Object
  • 简称DAO
  • 局限性适用于单系统应用程式

访问接口

DAO(Data Access Object)是一个数据访问接口,数据访问顾名思义就是与资料库打交道。夹在业务逻辑与资料库资源中间。
在核心J2EE模式中是这样介绍DAO模式的为了建立一个健壮的J2EE套用,应该将所有对数据源的访问操作抽象封装在一个公共API中。用程式设计的语言来说,就是建立一个接口,接口中定义了此应用程式中将会用到的所有事务方法。在这个应用程式中,当需要和数据源进行互动的时候则使用这个接口,并且编写一个单独的类来实现这个接口在逻辑上对应这个特定的数据存储。

访问对象

DAO(数据访问对象)是一种应用程式编程接口(API),存在于微软的Visual Basic中,它允许程式设计师请求对微软的Access资料库的访问。DAO是微软的第一个面向对象的资料库接口。DAO对象封闭了Access的Jet函式。通过Jet函式,它还可以访问其他的结构化查询语言(SQL)资料库。
J2EE开发人员使用数据访问对象(DAO)设计模式把底层的数据访问逻辑和高层的业务逻辑分开.实现DAO模式能够更加专注于编写数据访问代码.
我们先来回顾一下DAO设计模式和数据访问对象.
DAO基础
DAO模式是标準的J2EE设计模式之一.开发人员使用这个模式把底层的数据访问操作和上层的商务逻辑分开.一个典型的DAO实现有下列几个组件
1. 一个DAO工厂类;
2. 一个DAO接口;
3. 一个实现DAO接口的具体类;
4. 数据传递对象(有些时候叫做值对象).
具体的DAO类包含了从特定的数据源访问数据的逻辑。在下面的这段中你将学到设计和实现数据访问对象的技术。
事务划分
关于DAO要记住的一件重要事情是它们是事务性对象。每个被DAO执行的操作(对象创建,更新、或删除数据)都是和事务相关联的。同样的,事务划分(transaction demarcation)的概念是特别重要的。
事务划分是在事务界定定义中的方式。J2EE规范为事务划分描述了两种模式编程性事务(programmatic)和声明性事务(declarative).下表是对这两种模式的拆分
声明性事务划分 编程性事务划分
程式设计师使用EJB的部署描述符声明事务属性 程式设计师担负编写事务逻辑代码的责任。
运行时环境(EJB容器)使用这些属性来自动的管理事务。应用程式通过一个API接口来控制事务。

写盘方式

除去Data Access Object的意思,在光碟刻录方面DAO对应于Disk At Once(一次写盘方式),在使用刻录机刻录镜像档案时可以选择这种方式。
一次写盘是单次的写入方式,引导区、数据磁轨以及导出区都是一次性写入,一次写完之后光碟就关闭,即便此次写入没有写满整个刻录盘,也无法再写入其它数据。当引导区写入到光碟上时,并没有在该引导区标示出下一个可用的地址,光碟就被视为关闭,再也无法写入更多的数据。
这种写入模式主要用于光碟的複製,一次完成整张光碟的刻录。其特点是能使複製出来的光碟与源盘毫无二致。DAO写入方式可以轻鬆完成对于音乐CD、混合或特殊类型CD-ROM等数据轨之间存在间隙的光碟的複製,且可以确保数据结构与间隙长度都完全相同。值得一提的是,由于DAO写入方式把整张光碟当作一个区段来处理,一些小的失误都有可能导致整张光碟彻底报废,所以它对数据传送的稳定性和驱动器的性能有较高的要求。

相关信息

一、数据访问对象DAO的结构
上一章我们知道了DAO是什幺,它可以乾什幺,以及简单的了解了它是如何实现这一功能,这一章我们讲逐步学习DAO的结构。在将讲这一章之前,讲两个题外话
面向对象编程
大家对面向对象编程一定不陌生,但究竟什幺是面向对象编程,很多人一下子也说不出个所以然来;在VB的DAO中又是如何体现面向对象的呢,恐怕即便是使用了一段VB的网友也很难说清。这也难怪,VB本身并不是个完全的面向对象的编程环境,它的很多如动态数组等就不是面向对象的,但在DAO中是完全的面向对象的。其实面向对象的最初思想就是将数据和操作封装在一起,形成对象,而在DAO中正是体现了这一点,它将数据的值作为属性,数据的查询作为方法,数据值的变化作为事件,完全封装在DAO对象中,希望诸位盟友在使用中注意,逐步领悟面向对象的编程方法。
资料库前端开发系统和后台系统
经常由朋友说他会DELPHI,会PB,实际上用前端和后台的概念来看,他们都只是会一种前端开发工具而已,严格说起来并不能算会资料库的开发。人们往往只看到前台套用的功能而忽视了后台系统的套用,或者认为这两者根本就是一回事。前端后台概念用在单机上,就是VB与Access,用在网路中就是VB与SQLSever,只会VB或DELPHI是不能称为掌握资料库编程的,而且在编程中,要善于利用后台资料库提供功能,这样的程式运行起来更快,程式更精练。
题外话讲完,现在切入正题。DAO的结构如图所示
以上是DAO整体结构图,下面将分章节逐步讲述每个对象的使用
二、数据访问对象DAO的功能
1. DAO用来封装Data Source的..就比如,Connection conn = DAOFactory.createConnection()..
就可以把Driver. URL. username,passpword这一些放在DAO中
以后要更改资料库的类型.比如要把MYSQL换成Oracle的话..只需要更改DAOFactory里面的getConnection()里面的Driver.URL.之类的..
2. DAO也是把对资料库的操作(比如最基本的CRUD操作)全部封装在里面..
比如说你要插入一个新的用户..那幺.在DAO中我们只需要提供一个insertUser(User user)这一个方法就可以了..具体的操作是在DAO中实现的...
那幺对于要调用DAO的时候.我们只要知道insertUser(User)是用来插入一个新的用户...而不需要知道是如何实现的..
一般 DAO是与Abstract Factory模式一起来用的...
Factory来建立资料库和定位具体的DAO(比如说是UserDao..CustomerDao..)..一般将getConnection设定为static..也可以把HibernateSessionFactory这一个公共类放在这一AbstractFactory类中去...
public class DAOFactory {
private static final SessionFactory sessionFactory;
// 定义一个ThreadLocal .
static Session currentSession().....
public UserDao getUserDAO() { return new UserDaoImpl(sesssion);}
pulbic OtherDao getOtherDAO() { return new OtherDaoImpl(session);}
......
}
public interface UserDao {
public insertUser(FormBean)
public updateUser(FormBean);
}
然后就实现DAO的接口 (Struts的FormBean...VO来的..)
publicclassUserDaoImpl implements UserDao {
privateSession session;
public UserDaoImpl(Session session){
this.session = session;
}...
public insertUser(FormBean) {
..//..
session.save(UserPO);
..//..
return FormBean;
}
public FormBean updateUser(FormBean) {
..//..
session.update(UserPO);
..//..
return FormBean;
}
}
定义你的PO:
publicclassUserPO {
String firstname,lastname,password..........
}
Huhmmmm..........
三、实战套用——使用数据访问对象DAO
1 概述
Visual C++提供了对DAO的封装,MFC DAO类封装了DAO(资料库访问对象)的大部分功能,从而Visual C++程式就可以使用Visual C++提供的MFC DAO类方便的访问Microsoft Jet 资料库,编制简洁、有Visaul C++特色的资料库应用程式。
资料库访问对象(DAO)提供了一种通过程式代码创建和操纵资料库的机制。多个DAO对象构成一个体系结构,在这个结构里,各个DAO对象协同工作。DAO支持以下四个资料库选项
打开访问资料库(MDB档案)——MDB档案是一个自包含的资料库,它包括查询定义、安全信??须指定MDB档案的路径名。
直接打开ODBC数据源——这里有一个很重要的限制。不能找开以Jet引擎作为驱动程式的ODBC数据源;只可以使用具有自己的ODBC驱动程式DLL的数据源。
用Jet引擎找开ISAM型(索引顺序访问方法)数据源(包括dBase,FoxPro,Paradox,Btrieve,Excel或文本档案)——即使已经设定了ODBC数据源,要用Jet引擎来访问这些档案类型中的一种,也必须以ISAM型数据源的方式来找开档案,而不是以ODBC数据源的方式。
给ACCESS资料库附加外部表——这实际上是用DAO访问ODBC数据源的首选方法。使用ACCESS把ODBC表添加到一个MDB档案上,然后依照第一选项中介绍的方法用DAO找开这个MDB档案就可以了。用户也可以用ACCESS把IASM档案附加到一个MDB档案上。
2 套用DAO编程
2.1 打开资料库
CDaoWorkspace对象代表一个DAO Workspace对象,在MFC DAO体系结构中处于最高处,定义了一个用户的同资料库的会话,并包含打开的资料库,负责完成资料库的事务处理。我们可以使用隐含的workspace对象。
CDaoDatabase对象代表了一个到资料库的连线,在MFC中,是通过CDaoDatabase封装的。
在构造CDaoDatabase对象时,有如下两种方法
创建一个CDaoDatabase对象,并向其传递一个指向一个已经找开的CdaoWorkspace对象的指针。
创建一个CDaoDatabase对象,而不明确地指定使用的workspace,此时,MFC将创建一个新的临时的CDaoWorkspace对象。
如下代码所示
CDaoDatabasedb;
db.Open(“test.mdb”,FALSE,FALSE,_T(“”);
其中参数一包括要打开的档案的全路径名。
2.2 查询记录
一个DAO recordset对象,代表一个数据记录的集合,该集合是一个库表或者是一个查询的运行结果中的全部记录。CDaoRecorset对象有三种类型表、动态集、快照。
通常情况下,我们在应用程式中可以使用CDaoRecordset的导出类,这一般是通过ClassWizard或AppWizard来生成的。但我们也可以直接使用CDaoRecordset类生成的对象。此时,我们可以动态地绑定recordset对象的数据成员。
如下代码所示
COleVariant var;
long id;
CString str;
CDaoRecordset m_Set(&db);
m_Set.Open(“查询的SQL语句”);
while(!m_Set.IsEOF())
{
/
处理
m_Set.GetFieldValue(“ID”,var);
id=V_I4(var);
m_Set.GetFieldValue(“Name”,var);
str=var.pbVal;
/
m_Set.MoveNext();
}
m_Set.Close();
2.3 添加记录
添加记录用AddNew函式,此时用SetFieldValue来进行赋值。
如下代码所示
m_pDaoRecordset->AddNew ();
sprintf(strValue,"%s",>m_UserName );
m_pDaoRecordset->SetFieldValue ("UserName",strValue);
sprintf(strValue,"%d",m_PointId );
m_pDaoRecordset->SetFieldValue ("PointId",strValue);
dataSrc.SetDateTime (m_UpdateTime .GetYear ),m_UpdateTime .GetMonth ),m_UpdateTime .GetDay (),
m_UpdateTime .GetHour (),m_UpdateTime .GetMinute (),m_UpdateTime .GetSecond ());
valValue=dataSrc;
m_pDaoRecordset->SetFieldValue ("UpdateTime",valValue);
sprintf(strValue,"%f",m_pRecordset->m_OldValue );
m_pDaoRecordset->SetFieldValue ("OldValue",strValue);
sprintf(strValue,"%f",m_pRecordset->m_NewValue );
m_pDaoRecordset->SetFieldValue ("NewValue",strValue);
m_pDaoRecordset->Update ();
此时,要注意,日期时间型数据要用SetDataTime函式来赋值,这里面要用到COleVariant类型数据,具体用法可以参考有关帮助。
2.4 修改记录
修改记录用Edit()函式,把记录定位到要修改的位置,调用Edit函式,修改完成后,调用Update函式。
如下代码所示
m_Set.Edit();
m_Set.SetFieldValue(“列名”,”字元串”);
m_Set.Update();
2.5 删除记录
删除记录用Delete()函式,使用后不需调用Update()函式。
2.6 统计记录
可以使用如下代码来统计记录数
COleVariant varValue;
CDaoRecordset m_Set(&db);
m_Set.Open(dbOpenDynaset,”SQL语句”);
varValue=m_Set.GetFieldValue(0);
m_lMaxCount=V_I4(&varValue);
m_Set.Close();
如果是统计一张表中总记录,可以使用CDaoTableDef对象,如下代码所示
CDaoTableDefm_Set(&gUseDB);
Count=m_Set.GetRecordCount();
m_Set.Close();
不能用CDaoRecordset对象的GetRecordCount()来取得记录数。
3
使用DAO技术可以使我们方便的访问Microsoft Jet引擎资料库,由于Microsoft Jet不支持多执行绪,,必须限制调用到应用程式主执行绪的所有DAO。(来源CNET Networks )

Copyright@2015-2025 www.aizhengw.cn 癌症网版板所有