转贴一个关于DTO DAO VO BO PO POJO的^_^

DTO DAO VO BO PO POJO- -

                                      

potian 写道:

辨别一些名词:
1。VO:实际上很模糊,通常指ValueObject和ViewObject
2. ViewObject,界面展现需要的对象,如Struts的FormBean
3。Value Object,早期被作为ValueObject和Transfer Object的总称。实际上Value Object的真正意义在于它的内容,而不是身份
4。Transfer Object:数据传输对象,在应用程序不同层次之间传书对象,在一个分布式应用程序中,通常可以提高整体的性能
5。PO:也许就是Persistent Object,基本上就是Entity了
在不同的体系结构和实现方式里面,这些对象有可能重复,也有可能不重叠。如果你要做一个对所有的体系都能够方便移植的框架,那么每一种对象都需要严格区分。例如JDO的PO不能作为TO,应为它不能脱离PM,譬如你可以选择用ViewObject(如Struts的FOrmBean)直接作为TO,但在tapestry和Webwork里面就不合适了。但在很多时候,能够方便实用是最重要的,不要过度设计就是了。

robbin写道:

POJO是这样一个对象,它是一个普通的Java对象,它不同于EJB这样的带有繁重的容器控制功能的对象,它也不是那种被Enhanced过的对象,例如JDO的静态Enhance,也不是类似Hibernate那样被动态的byte code generation过。

也就是说POJO的概念是相对于其他那种被人动过手脚的class而言的,它是没有被动过手脚的。

曹晓钢

其实,为什么要做DAO?无非是:
1, 管理connection/transaction (hibernate的话就是session/transaction)
2, 便于进行统计/log操作;
3, 便于进行权限控制;

DAO模式中,有两类对象,一种是DAO,一种是valueObject。 在我们讨论的这个情况中,value object是hibernate对应的POJO.

那么,按照我的理解,DAO就是一个Transaction包装器,其逻辑结构就是商业的具体事务。此处,数据库的transaction和商业的事务是统一的。

这里有一篇不错的关于DAO的文章。

http://www-106.ibm.com/developerworks/java/library/j-dao/

 

BO 包含business logic
留在这备忘。
 
potian写道:

DTO? 我需要吗?

我手头上有两个项目,一个是我自己做的宾馆订房,另一个是和WeiHello一起构造他们的远程框架。

DTO的需求来源于两个方面,第一:

  • 我们的对象可能被某些框架或产品改变,附带某些服务端的系统资源,这些资源传输到远端以后毫无疑义,使得这些对象不能操作。JDO是一个典型的例子,它会增强对象,附带一个PersistenceManager。
  • 我们对象实现了remote接口,因此在RMI,所有对这些对象进行存取都会引发远程过程调用。这在性能上是不可接受的。

因此,DTO数据传输对象是为了在不同的进程空间传输数据。象第一个问题,如果我们的web应用和我们的业务代码在同一个进程空间,那么使用OpenPersistenceManagerInView模式应该可以解决。

但是DTO也造成了非常多的问题:

  • 对象数据化,DTO通常是纯数据,很少会附带业务,只是一堆数据
  • 对象平板化,DTO很少包含整个对象结构图,不然在Service端的解析和生成将非常复杂

也就是,我们很难把DTO当作真正的对象,而通常service就好像是几个函数,负责操纵DTO,标准的数据和行为分离。

我们的view在使用DTO改变系统信息时,只能存取平板的数据。传给service,每次service转发给DTOFactory进行翻译工作,反之每次service通过DAO取到的对象需要经过DTOFactory翻译成DTO平板数据,这个工作量非常之大。特别对于对象包含其他对象的情况,我们完全没办法直接使用这些对象本身提供的存取方法,而是必须用addXXX(long 包含对象的id,XXXDTO dto)这样的方法进行操作。

对于分布式应用程序来说(例如weihello的远程框架),这是一件无可奈何的事情。但是对于一个不需要分布的程序而言(注意不是集群),这是不是还有需要。粗略估计,至少在90%的Web应用程序不需要分布处理,也就是完全可以把业务代码和view放在同一个JVM中。

因此,我已经再也不愿意为了一个永远不可能分布的程序去实现这么一大堆DTO,结果就是我的代码减少到50%左右,我的所有代码可以非常简洁、OO的使用。感谢Hibernate的POJO持久和OGNL的强大功能。

万一我的程序在同一台服务器上负载过大怎么办,第一步是分离数据库服务器和应用服务器,因为应用服务器大量占用CPU的时候数据库服务器必定在CPU的低潮,反之亦然。这可以大大增加负载能力。我可以集群和负载均衡,当然还是不需要分布式处理。

如果我的应用程序负载到了这样也没办法解决,必须把每个部件分离到不同的机器上进行集群的时候,我再来考虑DTO。

 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: povobodtodaopojo都是Java编程中常用的缩写词。 - po:通常指持久化对象(Persistent Object),即数据库中的实体类,与数据库中的表一一对应。 - vo:通常指值对象(Value Object),用于封装业务逻辑中的数据,与前端展示相关。 - bo:通常指业务对象(Business Object),用于封装业务逻辑中的数据,与业务逻辑相关。 - dto:通常指数据传输对象(Data Transfer Object),用于在不同层之间传输数据,通常与前端展示无关。 - dao:通常指数据访问对象(Data Access Object),用于封装对数据库的访问,提供对数据库的增删改查操作。 - pojo:通常指普通Java对象(Plain Old Java Object),即普通的Java类,没有继承特定的接口或类,也没有实现特定的方法。 ### 回答2: po vo bo dto daopojo 是软件开发中经常使用的一些概念,用于设计和实现对象模型。下面将分别解释这些概念的含义及其在开发中的应用。 Po是指Persistant object(持久化对象),是映射到数据库表中的Java对象。Po主要用于数据交互,与数据库表结构一一对应,包含了与实体对象映射一一对应的Po实体。在开发中,如果需要进行数据库操作,则需要通过Po实体与数据库进行交互,从而实现对数据的增、删、改、查等操作。 Vo是指Value object(值对象),用于封装特定业务数据。VoPo不同的是,Vo不仅包含了与数据库映射的数据,还包含了其他一些数据字段,例如计算、统计字段等。Vo主要用于业务层的数据处理和交互,封装业务逻辑用于VO来完成,并作为业务组件的数据传递对象。 Bo是指Business object(业务对象),用于封装业务逻辑。Bo封装了特定的业务方法,实现相应的业务功能。Bo通过调用Dao进行持久化操作,或管理多个Bo进行协作完成更复杂的业务逻辑。 Dto是指Data transfer object(数据传输对象),主要用于接口层和远程调用时数据传输的封装。Dto通常包含一些传输时需要的字段,例如查询条件、分页信息等。Dto主要用于数据的传输,不包含业务逻辑。 Dao是指Data access object(数据访问对象),用于将数据访问与业务逻辑分离,Dao通过对Po对象进行CRUD操作,实现与数据库的交互。Dao在进行数据库操作时往往需要配合使用数据访问框架,例如Mybatis、Hibernate等。 Pojo是指Plain Ordinary Java object(简单Java对象),是一种纯粹的Java对象,不依赖于其他任何框架。Pojo一般用于传输数据、封装业务实体等。PojoVo比较相似,但Vo作为业务层的数据传输对象,常常包含业务逻辑,而Pojo则不会。 总之,这些概念在软件开发中的使用是相当普遍的,通过合理地使用这些概念,可以使开发者更加清晰地理解业务的实现方式,增加代码的可读性和可维护性。选择何种概念,最终需要根据具体的业务场景及功能需求决定。 ### 回答3: POVOBODTODAOPOJO都是Java中的术语。 PO指的是“持久化对象”,是用于描述持久化存储模型的Java对象,通常和数据库中的表一一对应。 在ORM(对象关系映射)框架中,PO可以将Java对象映射到数据库中的表,简化了数据的存储和持久化过程。 VO指的是“值对象”,是用于描述值的Java对象,通常是由一个或多个PO组成的。VO通常是用于在不同层之间传递数据的,例如将从数据库中查询出来的PO化成前台可以直接使用的VO,或者将前台传入的VO化成后台PO以进行数据的持久化存储。 BO指的是“业务对象”,是用于描述业务逻辑的Java对象,通常是由对应的多个POBODTO组成的。BO主要负责处理业务逻辑,可以看成是对PO进行多层封装后产生的对象,也可以是多个PO的组合。 DTO指的是“数据传输对象”,是用于数据传输的Java对象,通常是由一个或多个POBODTO组成的。DTO主要用于在不同模块之间传输数据,可以对数据进行封装和裁剪。 DAO指的是“数据访问对象”,是用于数据访问的Java对象,通常是负责封装数据访问层的操作,例如对数据库的增删改查等操作。DAO通过提供独立的接口,将访问数据的过程与业务分离,增强了代码的可重用性和可维护性。 POJO指的是“简单Java对象”,是一种不包含业务方法的Java对象,通常是用于封装数据的Java Bean。POJO与Java EE相关性较小,可以将其看成是一种简化的Java类实现方式,适用于需要快速实现业务逻辑的场景。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值