VO,PO ,BO,QO, DAO ,POJO【转】

  【转载地址】:http://www.blogjava.net/luofeng225/archive/2009/03/28/262620.html  

      因为看了有价值,才有了转的冲动 。转的“目的”我想有两个吧!第一,方便自己下次查阅;第二,通过对文章的格式重新编辑会更有印象。看书与看交流博客同样也是一种学习。其实来这儿也是为了学习。。。。

O/R Mapping 是 Object Relational  Mapping (对象关系映射)的缩写。 //这就是传说中的 ORM 缩写了。

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

VO ,值对象 (Value Object)
PO ,持久对象 (Persisent Object)
它们是由一组属性和属性的 get 和 set 方法组成。从结构上看,它们并没有什么不同的地方。但从其意义和本质上来看是完全不同的。

1. VO 是用 new 关键字创建,由 GC 回收的。   //GC垃圾收集机制
   PO 则是向数据库中添加新数据时创建,删除数据库中数据时削除的。并且它只能存活在一个数据库连接中,断开连接即被销毁。
2. VO 是值对象,精确点讲它是业务对象,是存活在业务层的,是业务逻辑使用的,它存活的目的就是为数据提供一个生存的地方。
   PO 则是有状态的,每个属性代表其当前的状态。它是物理数据的对象表示。使用它,可以使我们的程序与物理数据解耦,并且可以简化对象数据与物理数据之间的转换。

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

PO 的属性是跟数据库表的字段一一对应的。
PO 对象需要实现序列化接口。
-------------------------------------------------

 
java (PO,VO,TO,BO,DAO,POJO) 解释

PO(persistant object) 持久对象
在 o/r 映射的时候出现的概念,如果没有 o/r 映射,没有这个概念存在了。通常对应数据模型 ( 数据库 ), 本身还有部分业务逻辑的处理。可以看成是与数据库中的表相映射的 java 对象。最简单的 PO 就是对应数据库中某个表中的一条记录,多个记录可以用 PO 的集合。 PO 中应该不包含任何对数据库的操作。
 
Code:
  1. /*就是说在一些Object/Relation Mapping工具中,能够做到维护数据库表记录的persisent object完全是一个符合Java Bean规范的纯Java对象,没有增加别的属性和方法。全都是这样子的: */  
  2.   
  3. public class User {    
  4. private long id;    
  5. private String name;    
  6. public void setId(long id) {    
  7. this.id = id;    
  8. }    
  9. public void setName(String name) {    
  10. this.name=name;    
  11. }    
  12. public long getId() {    
  13. return id;    
  14. }    
  15. public String getName() {    
  16. return name;    
  17. }    
  18. }    
  19.   
  20.   
  21. /*本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/tianlincao/archive/2009/06/08/4251357.aspx*/  


VO(value object) 值对象
通常用于业务层之间的数据传递,和 PO 一样也是仅仅包含数据而已。但应是抽象出的业务对象 , 可以和表对应 , 也可以不 , 这根据业务的需要 . 个人觉得同 DTO( 数据传输对象 ), 在 web 上传递。
TO(Transfer Object) ,数据传输对象   //.....to 咋能翻译成数据传输对象呢?
在应用程序不同 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
建模框架 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值