【转】VO DAO BO

VO是跟数据库里表的映射,一个表对应一个VO
DAO是用VO来访问真实的表,对数据库的操做都在DAO中完成
BO是业务层,作逻辑处理的java

VO , PO , BO , QO, DAO ,POJO, web

 

O/R Mapping 是 Object Relational
Mapping (对象关系映射)的缩写。通俗点讲,就是将对象与关系数据库绑定,用对象来表示关系数据。在 O/R
Mapping 的世界里,有两个基本的也是重要的东东须要了解,即 VO , PO 。数据库

VO ,值对象 (Value Object) , 设计模式

PO ,持久对象 (Persisent
Object) ,它们是由一组属性和属性的 get 和 set 方法组成。从结构上看,它们并无什么不一样的地方。但从其意义和本质上来看是彻底不一样的。
1. VO 是用 new 关键字建立,由 GC 回收的。
   PO 则是向数据库中添加新数据时建立,删除数据库中数据时削除的。而且它只能存活在一个数据库链接中,断开链接即被销毁。
2. VO 是值对象,精确点讲它是业务对象,是存活在业务层的,是业务逻辑使用的,它存活的目的就是为数据提供一个生存的地方。
   PO 则是有状态的,每一个属性表明其当前的状态。它是物理数据的对象表示。使用它,可使咱们的程序与物理数据解耦,而且能够简化对象数据与物理数据之间的转换。
3. VO 的属性是根据当前业务的不一样而不一样的,也就是说,它的每个属性都一一对应当前业务逻辑所须要的数据的名称。
PO 的属性是跟数据库表的字段一一对应的。
PO 对象须要实现序列化接口。
-------------------------------------------------app

java 的 (PO,VO,TO,BO,DAO,POJO) 解释
PO(persistant object) 持久对象
在 o/r 映射的时候出现的概念,若是没有 o/r 映射,没有这个概念存在了。一般对应数据模型 ( 数据库 ), 自己还有部分业务逻辑的处理。能够当作是与数据库中的表相映射的 java 对象。最简单的 PO 就是对应数据库中某个表中的一条记录,多个记录能够用 PO 的集合。 PO 中应该不包含任何对数据库的操做。
VO(value object) 值对象
一般用于业务层之间的数据传递,和 PO 同样也是仅仅包含数据而已。但应是抽象出的业务对象 , 能够和表对应 , 也能够不 , 这根据业务的须要 . 我的以为同 DTO( 数据传输对象 ), 在 web 上传递。
TO(Transfer Object) ,数据传输对象
在应用程序不一样 tie( 关系 ) 之间传输的对象
BO(business object) 业务对象
从业务模型的角度看 , 见 UML 元件领域模型中的领域对象。封装业务逻辑的 java 对象 , 经过调用 DAO 方法 , 结合 PO,VO 进行业务操做。
business object: 业务对象
主要做用是把业务逻辑封装为一个对象。这个对象能够包括一个或多个其它的对象。
好比一个简历,有教育经历、工做经历、社会关系等等。
咱们能够把教育经历对应一个 PO ,工做经历对应一个 PO ,社会关系对应一个 PO 。
创建一个对应简历的 BO 对象处理简历,每一个 BO 包含这些 PO 。
这样处理业务逻辑时,咱们就能够针对 BO 去处理。
QO :查询对象
POJO(plain ordinary java object) 简单无规则 java 对象
纯的传统意义的 java 对象。就是说在一些 Object/Relation
Mapping 工具中,可以作到维护数据库表记录的 persisent
object 彻底是一个符合 Java Bean 规范的纯 Java 对象,没有增长别的属性和方法。个人理解就是最基本的 Java Bean ,只有属性字段及 setter 和 getter 方法!。
DAO(data access object) 数据访问对象
是 一个 sun 的一个标准 j2ee 设计模式, 这个模式中有个接口就是 DAO ,它负持久层的操做。为业务层提供接口。此对象用于访问数据库。一般和 PO 结合使用, DAO 中包含了各类数据库的操做方法。经过它的方法 , 结合 PO 对数据库进行相关的操做。夹在业务逻辑与数据库资源中间。配合 VO,
提供数据库的 CRUD 操做 ... 框架

 

 

DTO :
Data Transfer Object 数据传输对象
主要用于远程调用等须要大量传输对象的地方。
好比咱们一张表有 100 个字段,那么对应的 PO 就有 100 个属性。
可是咱们界面上只要显示 10 个字段,
客户端用 WEB service 来获取数据,没有必要把整个 PO 对象传递到客户端,
这时咱们就能够用只有这 10 个属性的 DTO 来传递结果到客户端,这样也不会暴露服务端表结构 . 到达客户端之后,若是用这个对象来对应界面显示,那此时它的身份就转为 VO工具

 


DAO :数据访问对象 —— 同时还有 DAO 模式
DTO :数据传输对象 —— 同时还有 DTO 模式设计

 

 


O/R Mapper 对象 / 关系 映射
定义好全部的 mapping 以后,这个 O/R
Mapper 能够帮咱们作不少的工做。经过这些 mappings, 这个 O/R
Mapper 能够生成全部的关于对象保存,删除,读取的 SQL 语句,咱们再也不须要写那么多行的 DAL 代码了。
实体 Model( 实体模式 )
DAL( 数据访问层 )
IDAL( 接口层 )
DALFactory( 类工厂 )
BLL( 业务逻辑层 )
BOF     Business Object Framework       业务对象框架
SOA     Service Orient Architecture     面向服务的设计
EMF     Eclipse Model Framework       
Eclipse 建模框架对象

相关文章
相关标签/搜索