java有几种对象(PO,VO,DAO,DTO,BO,POJO详解)

PO(Persistent Object) 持久对象 

       在O/R映射的时候出现的概念,如果没有o/r映射,没有这个概念存在了。通常对应数据模型(数据库),本身还有部分业务逻辑的处理。可以看成是与数据库中的表相映射的java对象。最简单的PO就是对应数据库中某个表中的一条记录,多个记录可以用PO的集合。PO中应该不包含任何对数据库的操作。


VO(Value Object) 值对象 

1.VO是用new关键字创建,由GC回收的。

2.VO是值对象,精确点讲它是业务对象,是存活在业务层的,是业务逻辑使用的,它存活的目的就是为数据提供一个生存的地方。

3.VO的属性是根据当前业务的不同而不同的,也就是说,它的每一个属性都一一对应当前业务逻辑所需要的数据的名称。

       通常用于业务层之间的数据传递,和PO一样也是仅仅包含数据而已。但应是抽象出的业务对象,可以和表对应,也可以不,这根据业务的需要.个人觉得同DTO(数据传输对象),在web上传递。  


DTO( Data Transfer Object)

数据传输对象    在应用程序不同tie(关系)之间传输的对象  


BO(Business Object) 业务对象 

    从业务模型的角度看,见UML元件领域模型中的领域对象。封装业务逻辑的java对象,通过调用DAO方法,结合PO,VO进行业务操作。这个对象可以包括一个或多个其它的对象。比如一个简历,有教育经历、工作经历、 关系等等。 

我们可以把教育经历对应一个PO,工作经历对应一个PO, 关系对应一个PO。 建立一个对应简历的BO对象处理简历,每个BO包含这些PO。 这样处理业务逻辑时,我们就可以针对BO去处理。  

(BO是很多人都不容易理解的地方,这里特别解释一下) 关于BO主要有三种概念  

1 、只包含业务对象的属性; 

2 、只包含业务方法;

3 、两者都包含。 

在实际使用中,认为哪一种概念正确并不重要,关键是实际应用中适合自己项目的需要。


POJO(Plain Ordinary Java Object) 

简单无规则java对象    纯的传统意义的java对象。就是说在一些Object/Relation 

Mapping工具中,能够做到维护数据库表记录的persisent  object完全是一个符合Java Bean规范的纯Java对象,没有增加别的属性和方法。我的理解就是最基本的Java Bean,只有属性字段及setter和getter方法!。 


DAO(Data Access Object) 数据访问对象 

    DAO是一个sun的一个标准j2ee设计模式,这个模式中有个接口就是DAO,它负责持久层的操作,为业务层提供接口。此对象用于访问数据库。通常和PO结合使用,DAO中包含了各种数据库的操作方法。通过它的方法,结合PO对数据库进行相关的操作。夹在业务


逻辑与数据库资源中间。配合VO,提供数据库的CRUD操作。  

O/R Mapper 对象/关系映射     定义好所有的Mapping之后,这个O/R 

Mapper可以帮我们做很多的工作。通过这些mappings,这个O/R 

Mapper可以生成所有的关于对象保存,删除,读取的SQL语句,我们不再需要写那么多行的DAL代码了。   

EM(Entity Model)实体模式 

DAL(Data Access Layout)(数据访问层) IDAL(Interface Data Access Layout)接口层 DALFactory类工厂 

BLL(Business Logic Level)业务逻辑层 

BOF(Business Object Framework)业务对象框架 SOA (Service Orient Architecture)面向服务的设计 EMF(Eclipse Model Framework) Eclipse建模框架



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值