关于JAVA的PO与VO

我一直很矛盾:是否PO可以用在商业逻辑层,当作VO使用;还是将两者分开。在许多论坛上,这两者之争也很激烈。所以今天我打算把我的想法写下来。
首先,java有几种对象(PO,VO,DAO,BO,POJO)
一、PO:persistant object 持久对象,可以看成是与数据库中的表相映射的java对象。使用Hibernate来生成PO是不错的选择。
二、VO:value object值对象。通常用于业务层之间的数据传递,和PO一样也是仅仅包含数据而已。但应是抽象出的业务对象,可以和表对应,也可以不,这根据业务的需要.
有一种观点就是:PO只能用在数据层,VO用在商业逻辑层和表示层。各层操作属于该层自己的数据对象,这样就可以降低各层之间的耦合,便于以后系统的维护和扩展。如果将PO用在各个层中就相当于我们使用全局变量,我们知道在OO设计非常不赞成使用全局变量。
但是每次都得进行VO-PO的转换,也确实很烦。我觉得有时候也可以在某个商业逻辑或者表示层使用PO,此时在这个商业逻辑的过程中PO的状态是不发生变化的,比如显示一条商品详细信息的商业逻辑。
在开发过的项目中,规模都很小,我一直都把PO当VO用,因为PO确实很方便,结合Hibernate的DAO,我使用JAVA的集合对象作为值传递的载体,当然Struts也是我的不二之选。
我认为:在一些直观的,简单的,不易发生变化的,不需要涉及多个PO时,传递值还是使用PO好,这样可以减少大量的工作量(也就意味着减少bug,减少风险),也不需要担心未来的维护工作!

[转]
http://www.blogjava.net/xsm1034999/archive/2007/11/11/159706.html
### JavaPO、DO、VO、DTO 的概念及区别 #### PO (Persistent Object) PO 表示持久化对象,主要用于表示数据库中的记录。这类对象通常某种持久化机制(如 Hibernate 或 JPA)关联,具有映射关系配置以便能够被保存至数据库或从中读取。 ```java @Entity public class UserPO { @Id private Long id; private String name; // getters and setters... } ``` 这种类型的对象设计遵循 ORM 思想,即对象关系映射[^1]。 #### DO (Data Object) DO 即数据访问层实体类,一般对应着数据库表结构,用来封装来自数据库的数据。它主要存在于 DAO 层中作为参数传递给存储过程或其他 SQL 查询语句执行的结果集载体。虽然有时会看到有人把 DO 和 PO 混淆使用,但实际上两者是有区别的:DO 更多的是指一种抽象意义上的存在形式而不是具体的实现方式;而 PO 则更倾向于具体的技术框架下的实例化表达[^2]。 ```java @Table(name="users") public class UserDO implements Serializable{ private static final long serialVersionUID = 1L; @Column(name="id", nullable=false) private Integer userId; @Column(name="username", length=50,nullable=true) private String userName; // other fields... // getter/setter methods... } ``` #### VO (View Object) VO 主要是为了适应前端页面显示需求所创建的一种模型对象。其目的是简化并优化向客户端传输的信息量以及提高用户体验感。因此,在实际开发过程中经常会遇到这样的情况——同一个业务逻辑可能需要根据不同界面的要求构建多个版本的 ViewObject 来满足各自特有的展现特性[^3]。 ```java public class UserVO { private String displayName; private int age; public UserVO(String displayName, int age){ this.displayName = displayName; this.age = age; } // getters and setters... } ``` #### DTO (Data Transfer Object) DTO 被定义为用于远程调用间交换信息的数据容器。当应用程序的不同部分之间相互通信时(比如跨进程甚至跨越网络边界),就需要采用这种方式来减少不必要的属性暴露从而保护内部系统的安全性同时也降低了通信成本。此外,通过引入专门负责携带这些信息的中间件还可以进一步增强程序架构上的灵活性和可维护性[^4]。 ```java public class UserDTO { private String username; private List<String> roles; // constructor/getters/setters omitted for brevity. } ``` ### 使用场景总结 - **PO**: 当涉及到任何有关于将内存里的状态同步回磁盘文件或是其他任何形式长期储存介质的操作时; - **DO**: 数据库交互层面,特别是在 Repository/DAO 接口中充当输入输出参数的角色; - **VO**: 准备好要呈现给用户的最终形态之前做最后一次加工处理的地方; - **DTO**: 需要在分布式环境中共享资源或者对外提供 API 接口的情况下特别有用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值